Bleak Faith: Forsaken Wiki
bleakfaith_en
https://bleakfaith.wiki.gg/
MediaWiki 1.43.3
first-letter
Media
Special
Talk
User
User talk
Meta
Meta talk
File
File talk
MediaWiki
MediaWiki talk
Template
Template talk
Help
Help talk
Category
Category talk
Module
Module talk
Map
Map talk
Template:Error
10
335
437
2013-10-29T00:20:58Z
wikipedia>Mr. Stradivarius
0
Protected Template:Error: [[WP:High-risk templates|Highly visible template]]: 32,000 transclusions ([Edit=Allow only template editors and admins] (indefinite) [Move=Allow only template editors and admins] (indefinite))
wikitext
text/x-wiki
{{#invoke:Error|error|{{{message|{{{1}}}}}}|tag={{{tag|}}}}}<noinclude>
{{documentation}}
</noinclude>
5da54c14258c1b1755a03bccb88dc5d9d0cefb56
Module:Namespace detect
828
329
425
2014-04-05T17:01:23Z
wikipedia>Mr. Stradivarius
0
use demopage instead of page as the main "page" parameter
Scribunto
text/plain
--[[
--------------------------------------------------------------------------------
-- --
-- NAMESPACE DETECT --
-- --
-- This module implements the {{namespace detect}} template in Lua, with a --
-- few improvements: all namespaces and all namespace aliases are supported, --
-- and namespace names are detected automatically for the local wiki. The --
-- module can also use the corresponding subject namespace value if it is --
-- used on a talk page. Parameter names can be configured for different wikis --
-- by altering the values in the "cfg" table in --
-- Module:Namespace detect/config. --
-- --
--------------------------------------------------------------------------------
--]]
local data = mw.loadData('Module:Namespace detect/data')
local argKeys = data.argKeys
local cfg = data.cfg
local mappings = data.mappings
local yesno = require('Module:Yesno')
local mArguments -- Lazily initialise Module:Arguments
local mTableTools -- Lazily initilalise Module:TableTools
local ustringLower = mw.ustring.lower
local p = {}
local function fetchValue(t1, t2)
-- Fetches a value from the table t1 for the first key in array t2 where
-- a non-nil value of t1 exists.
for i, key in ipairs(t2) do
local value = t1[key]
if value ~= nil then
return value
end
end
return nil
end
local function equalsArrayValue(t, value)
-- Returns true if value equals a value in the array t. Otherwise
-- returns false.
for i, arrayValue in ipairs(t) do
if value == arrayValue then
return true
end
end
return false
end
function p.getPageObject(page)
-- Get the page object, passing the function through pcall in case of
-- errors, e.g. being over the expensive function count limit.
if page then
local success, pageObject = pcall(mw.title.new, page)
if success then
return pageObject
else
return nil
end
else
return mw.title.getCurrentTitle()
end
end
-- Provided for backward compatibility with other modules
function p.getParamMappings()
return mappings
end
local function getNamespace(args)
-- This function gets the namespace name from the page object.
local page = fetchValue(args, argKeys.demopage)
if page == '' then
page = nil
end
local demospace = fetchValue(args, argKeys.demospace)
if demospace == '' then
demospace = nil
end
local subjectns = fetchValue(args, argKeys.subjectns)
local ret
if demospace then
-- Handle "demospace = main" properly.
if equalsArrayValue(argKeys.main, ustringLower(demospace)) then
ret = mw.site.namespaces[0].name
else
ret = demospace
end
else
local pageObject = p.getPageObject(page)
if pageObject then
if pageObject.isTalkPage then
-- Get the subject namespace if the option is set,
-- otherwise use "talk".
if yesno(subjectns) then
ret = mw.site.namespaces[pageObject.namespace].subject.name
else
ret = 'talk'
end
else
ret = pageObject.nsText
end
else
return nil -- return nil if the page object doesn't exist.
end
end
ret = ret:gsub('_', ' ')
return ustringLower(ret)
end
function p._main(args)
-- Check the parameters stored in the mappings table for any matches.
local namespace = getNamespace(args) or 'other' -- "other" avoids nil table keys
local params = mappings[namespace] or {}
local ret = fetchValue(args, params)
--[[
-- If there were no matches, return parameters for other namespaces.
-- This happens if there was no text specified for the namespace that
-- was detected or if the demospace parameter is not a valid
-- namespace. Note that the parameter for the detected namespace must be
-- completely absent for this to happen, not merely blank.
--]]
if ret == nil then
ret = fetchValue(args, argKeys.other)
end
return ret
end
function p.main(frame)
mArguments = require('Module:Arguments')
local args = mArguments.getArgs(frame, {removeBlanks = false})
local ret = p._main(args)
return ret or ''
end
function p.table(frame)
--[[
-- Create a wikitable of all subject namespace parameters, for
-- documentation purposes. The talk parameter is optional, in case it
-- needs to be excluded in the documentation.
--]]
-- Load modules and initialise variables.
mTableTools = require('Module:TableTools')
local namespaces = mw.site.namespaces
local cfg = data.cfg
local useTalk = type(frame) == 'table'
and type(frame.args) == 'table'
and yesno(frame.args.talk) -- Whether to use the talk parameter.
-- Get the header names.
local function checkValue(value, default)
if type(value) == 'string' then
return value
else
return default
end
end
local nsHeader = checkValue(cfg.wikitableNamespaceHeader, 'Namespace')
local aliasesHeader = checkValue(cfg.wikitableAliasesHeader, 'Aliases')
-- Put the namespaces in order.
local mappingsOrdered = {}
for nsname, params in pairs(mappings) do
if useTalk or nsname ~= 'talk' then
local nsid = namespaces[nsname].id
-- Add 1, as the array must start with 1; nsid 0 would be lost otherwise.
nsid = nsid + 1
mappingsOrdered[nsid] = params
end
end
mappingsOrdered = mTableTools.compressSparseArray(mappingsOrdered)
-- Build the table.
local ret = '{| class="wikitable"'
.. '\n|-'
.. '\n! ' .. nsHeader
.. '\n! ' .. aliasesHeader
for i, params in ipairs(mappingsOrdered) do
for j, param in ipairs(params) do
if j == 1 then
ret = ret .. '\n|-'
.. '\n| <code>' .. param .. '</code>'
.. '\n| '
elseif j == 2 then
ret = ret .. '<code>' .. param .. '</code>'
else
ret = ret .. ', <code>' .. param .. '</code>'
end
end
end
ret = ret .. '\n|-'
.. '\n|}'
return ret
end
return p
a4757000273064f151f0f22dc0e139092e5ff443
Module:Error
828
334
435
2016-11-21T11:11:11Z
wikipedia>Materialscientist
0
Changed protection level for "[[Module:Error]]": [[WP:High-risk templates|Highly visible template]] ([Edit=Require template editor access] (indefinite) [Move=Require template editor access] (indefinite))
Scribunto
text/plain
-- This module implements {{error}}.
local p = {}
local function _error(args)
local tag = mw.ustring.lower(tostring(args.tag))
-- Work out what html tag we should use.
if not (tag == 'p' or tag == 'span' or tag == 'div') then
tag = 'strong'
end
-- Generate the html.
return tostring(mw.html.create(tag)
:addClass('error')
:wikitext(tostring(args.message or args[1] or error('no message specified', 2)))
)
end
function p.error(frame)
local args
if type(frame.args) == 'table' then
-- We're being called via #invoke. The args are passed through to the module
-- from the template page, so use the args that were passed into the template.
args = frame.args
else
-- We're being called from another module or from the debug console, so assume
-- the args are passed in directly.
args = frame
end
-- if the message parameter is present but blank, change it to nil so that Lua will
-- consider it false.
if args.message == "" then
args.message = nil
end
return _error(args)
end
return p
f77bd720c216b5626efe795d3b49462d50971f7d
Module:Namespace detect/config
828
330
427
2020-04-01T06:12:44Z
wikipedia>MusikAnimal
0
1 revision imported
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Namespace detect configuration data --
-- --
-- This module stores configuration data for Module:Namespace detect. Here --
-- you can localise the module to your wiki's language. --
-- --
-- To activate a configuration item, you need to uncomment it. This means --
-- that you need to remove the text "-- " at the start of the line. --
--------------------------------------------------------------------------------
local cfg = {} -- Don't edit this line.
--------------------------------------------------------------------------------
-- Parameter names --
-- These configuration items specify custom parameter names. Values added --
-- here will work in addition to the default English parameter names. --
-- To add one extra name, you can use this format: --
-- --
-- cfg.foo = 'parameter name' --
-- --
-- To add multiple names, you can use this format: --
-- --
-- cfg.foo = {'parameter name 1', 'parameter name 2', 'parameter name 3'} --
--------------------------------------------------------------------------------
---- This parameter displays content for the main namespace:
-- cfg.main = 'main'
---- This parameter displays in talk namespaces:
-- cfg.talk = 'talk'
---- This parameter displays content for "other" namespaces (namespaces for which
---- parameters have not been specified):
-- cfg.other = 'other'
---- This parameter makes talk pages behave as though they are the corresponding
---- subject namespace. Note that this parameter is used with [[Module:Yesno]].
---- Edit that module to change the default values of "yes", "no", etc.
-- cfg.subjectns = 'subjectns'
---- This parameter sets a demonstration namespace:
-- cfg.demospace = 'demospace'
---- This parameter sets a specific page to compare:
cfg.demopage = 'page'
--------------------------------------------------------------------------------
-- Table configuration --
-- These configuration items allow customisation of the "table" function, --
-- used to generate a table of possible parameters in the module --
-- documentation. --
--------------------------------------------------------------------------------
---- The header for the namespace column in the wikitable containing the list of
---- possible subject-space parameters.
-- cfg.wikitableNamespaceHeader = 'Namespace'
---- The header for the wikitable containing the list of possible subject-space
---- parameters.
-- cfg.wikitableAliasesHeader = 'Aliases'
--------------------------------------------------------------------------------
-- End of configuration data --
--------------------------------------------------------------------------------
return cfg -- Don't edit this line.
0e4ff08d13c4b664d66b32c232deb129b77c1a56
Module:Namespace detect/data
828
331
429
2020-04-01T06:12:45Z
wikipedia>MusikAnimal
0
1 revision imported
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Namespace detect data --
-- This module holds data for [[Module:Namespace detect]] to be loaded per --
-- page, rather than per #invoke, for performance reasons. --
--------------------------------------------------------------------------------
local cfg = require('Module:Namespace detect/config')
local function addKey(t, key, defaultKey)
if key ~= defaultKey then
t[#t + 1] = key
end
end
-- Get a table of parameters to query for each default parameter name.
-- This allows wikis to customise parameter names in the cfg table while
-- ensuring that default parameter names will always work. The cfg table
-- values can be added as a string, or as an array of strings.
local defaultKeys = {
'main',
'talk',
'other',
'subjectns',
'demospace',
'demopage'
}
local argKeys = {}
for i, defaultKey in ipairs(defaultKeys) do
argKeys[defaultKey] = {defaultKey}
end
for defaultKey, t in pairs(argKeys) do
local cfgValue = cfg[defaultKey]
local cfgValueType = type(cfgValue)
if cfgValueType == 'string' then
addKey(t, cfgValue, defaultKey)
elseif cfgValueType == 'table' then
for i, key in ipairs(cfgValue) do
addKey(t, key, defaultKey)
end
end
cfg[defaultKey] = nil -- Free the cfg value as we don't need it any more.
end
local function getParamMappings()
--[[
-- Returns a table of how parameter names map to namespace names. The keys
-- are the actual namespace names, in lower case, and the values are the
-- possible parameter names for that namespace, also in lower case. The
-- table entries are structured like this:
-- {
-- [''] = {'main'},
-- ['wikipedia'] = {'wikipedia', 'project', 'wp'},
-- ...
-- }
--]]
local mappings = {}
local mainNsName = mw.site.subjectNamespaces[0].name
mainNsName = mw.ustring.lower(mainNsName)
mappings[mainNsName] = mw.clone(argKeys.main)
mappings['talk'] = mw.clone(argKeys.talk)
for nsid, ns in pairs(mw.site.subjectNamespaces) do
if nsid ~= 0 then -- Exclude main namespace.
local nsname = mw.ustring.lower(ns.name)
local canonicalName = mw.ustring.lower(ns.canonicalName)
mappings[nsname] = {nsname}
if canonicalName ~= nsname then
table.insert(mappings[nsname], canonicalName)
end
for _, alias in ipairs(ns.aliases) do
table.insert(mappings[nsname], mw.ustring.lower(alias))
end
end
end
return mappings
end
return {
argKeys = argKeys,
cfg = cfg,
mappings = getParamMappings()
}
d224f42a258bc308ef3ad8cc8686cd7a4f47d005
Module:About
828
339
445
2020-07-14T13:59:23Z
wikipedia>Nihiltres
0
Removed defaultOptions.namespace as redundant, per request on talk by Andrybak
Scribunto
text/plain
local mArguments --initialize lazily
local mHatnote = require('Module:Hatnote')
local mHatList = require('Module:Hatnote list')
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
function p.about (frame)
-- A passthrough that gets args from the frame and all
mArguments = require('Module:Arguments')
args = mArguments.getArgs(frame)
return p._about(args)
end
function p._about (args, options)
-- Produces "about" hatnote.
-- Type checks and defaults
checkType('_about', 1, args, 'table', true)
args = args or {}
checkType('_about', 2, options, 'table', true)
options = options or {}
local defaultOptions = {
aboutForm = 'This %s is about %s. ',
PageType = require('Module:Pagetype').main(),
otherText = nil, --included for complete list
sectionString = 'section'
}
for k, v in pairs(defaultOptions) do
if options[k] == nil then options[k] = v end
end
-- Set initial "about" string
local pageType = (args.section and options.sectionString) or options.PageType
local about = ''
if args[1] then
about = string.format(options.aboutForm, pageType, args[1])
end
--Allow passing through certain options
local fsOptions = {
otherText = options.otherText,
extratext = args.text
}
local hnOptions = {
selfref = args.selfref
}
-- Set for-see list
local forSee = mHatList._forSee(args, 2, fsOptions)
-- Concatenate and return
return mHatnote._hatnote(about .. forSee, hnOptions)
end
return p
1abb25315b25b63b97d98ecae17733cbea8fcc6a
Module:Convert/wikidata
828
723
1109
2021-05-06T05:08:27Z
wikipedia>Johnuniq
0
update from sandbox per [[Template talk:Convert#Module version 25]]
Scribunto
text/plain
-- Functions to access Wikidata for Module:Convert.
local Collection = {}
Collection.__index = Collection
do
function Collection:add(item)
if item ~= nil then
self.n = self.n + 1
self[self.n] = item
end
end
function Collection:join(sep)
return table.concat(self, sep)
end
function Collection:remove(pos)
if self.n > 0 and (pos == nil or (0 < pos and pos <= self.n)) then
self.n = self.n - 1
return table.remove(self, pos)
end
end
function Collection:sort(comp)
table.sort(self, comp)
end
function Collection.new()
return setmetatable({n = 0}, Collection)
end
end
local function strip_to_nil(text)
-- If text is a non-empty string, return its trimmed content,
-- otherwise return nothing (empty string or not a string).
if type(text) == 'string' then
return text:match('(%S.-)%s*$')
end
end
local function frequency_unit(value, unit_table)
-- For use when converting m to Hz.
-- Return true, s where s = name of unit's default output unit,
-- or return false, t where t is an error message table.
-- However, for simplicity a valid result is always returned.
local unit
if unit_table._symbol == 'm' then
-- c = speed of light in a vacuum = 299792458 m/s
-- frequency = c / wavelength
local w = value * (unit_table.scale or 1)
local f = 299792458 / w -- if w == 0, f = math.huge which works here
if f >= 1e12 then
unit = 'THz'
elseif f >= 1e9 then
unit = 'GHz'
elseif f >= 1e6 then
unit = 'MHz'
elseif f >= 1e3 then
unit = 'kHz'
else
unit = 'Hz'
end
end
return true, unit or 'Hz'
end
local function wavelength_unit(value, unit_table)
-- Like frequency_unit but for use when converting Hz to m.
local unit
if unit_table._symbol == 'Hz' then
-- Using 0.9993 rather than 1 avoids rounding which would give results
-- like converting 300 MHz to 100 cm instead of 1 m.
local w = 1 / (value * (unit_table.scale or 1)) -- Hz scale is inverted
if w >= 0.9993e6 then
unit = 'Mm'
elseif w >= 0.9993e3 then
unit = 'km'
elseif w >= 0.9993 then
unit = 'm'
elseif w >= 0.9993e-2 then
unit = 'cm'
elseif w >= 0.9993e-3 then
unit = 'mm'
else
unit = 'um'
end
end
return true, unit or 'm'
end
local specials = {
frequency = { frequency_unit },
wavelength = { wavelength_unit },
--------------------------------------------------------------------------------
-- Following is a removed experiment to show two values as a range
-- using '-' as the separator.
-- frequencyrange = { frequency_unit, '-' },
-- wavelengthrange = { wavelength_unit, '-' },
}
local function make_unit(units, parms, uid)
-- Return a unit code for convert or nil if unit unknown.
-- If necessary, add a dummy unit to parms so convert will use it
-- for the input without attempting a conversion since nothing
-- useful is available (for example, with unit volt).
local unit = units[uid]
if type(unit) ~= 'table' then
return nil
end
local ucode = unit.ucode
if ucode and not unit.si then
return ucode -- a unit known to convert
end
parms.opt_ignore_error = true
ucode = ucode or unit._ucode -- must be a non-empty string
local ukey, utable
if unit.si then
local base = units[unit.si]
ukey = base.symbol -- must be a non-empty string
local n1 = base.name1
local n2 = base.name2
if not n1 then
n1 = ukey
n2 = n2 or n1 -- do not append 's'
end
utable = {
_symbol = ukey,
_name1 = n1,
_name2 = n2,
link = unit.link or base.link,
utype = n1,
prefixes = 1,
}
else
ukey = ucode
utable = {
symbol = ucode, -- must be a non-empty string
name1 = unit.name1, -- if nil, uses symbol
name2 = unit.name2, -- if nil, uses name1..'s'
link = unit.link, -- if nil, uses name1
utype = unit.name1 or ucode,
}
end
utable.scale = 1
utable.default = ''
utable.defkey = ''
utable.linkey = ''
utable.bad_mcode = ''
parms.unittable = { [ukey] = utable }
return ucode
end
local function matches_qualifier(statement, qual)
-- Return:
-- false, nil : if statement does not match specification
-- true, nil : if matches, and statement has no qualifier
-- true, sq : if matches, where sq is the statement's qualifier
-- A match means that no qualifier was specified (qual == nil), or that
-- the statement has a qualifier matching the specification.
-- If a match occurs, the caller needs the statement's qualifier (if any)
-- so statements that duplicate the qualifier are not used, after the first.
-- Then, if convert is showing all values for a property such as the diameter
-- of a telescope's mirror (diameters of primary and secondary mirrors), it
-- will not show alternative values that could in principle be present for the
-- same item (telescope) and property (diameter) and qualifier (primary/secondary).
local target = (statement.qualifiers or {}).P518 -- P518 is "applies to part"
if type(target) == 'table' then
for _, q in ipairs(target) do
if type(q) == 'table' then
local value = (q.datavalue or {}).value
if value then
if qual == nil or qual == value.id then
return true, value.id
end
end
end
end
end
if qual == nil then
return true, nil -- only occurs if statement has no qualifier
end
return false, nil -- statement's qualifier is not relevant because statement will be skipped
end
local function get_statements(parms, pid)
-- Get specified item and return a list of tables with each statement for property pid.
-- Each table is of form {statqual=sq, stmt=statement} where sq = statement qualifier (nil if none).
-- Statements are in Wikidata's order except that those with preferred rank
-- are first, then normal rank. Any other rank is ignored.
local stored = {} -- qualifiers of statements that are first for the qualifier, and will be returned
local qid = strip_to_nil(parms.qid) -- nil for current page's item, or an item id (expensive)
local qual = strip_to_nil(parms.qual) -- nil or id of wanted P518 (applies to part) item in qualifiers
local result = Collection.new()
local entity = mw.wikibase.getEntity(qid)
if type(entity) == 'table' then
local statements = (entity.claims or {})[pid]
if type(statements) == 'table' then
for _, rank in ipairs({ 'preferred', 'normal' }) do
for _, statement in ipairs(statements) do
if type(statement) == 'table' and rank == statement.rank then
local is_match, statqual = matches_qualifier(statement, qual)
if is_match then
result:add({ statqual = statqual, stmt = statement })
end
end
end
end
end
end
return result
end
local function input_from_property(tdata, parms, pid)
-- Given that pid is a Wikidata property identifier like 'P123',
-- return a collection of {amount, ucode} pairs (two strings)
-- for each matching item/property, or return nothing.
--------------------------------------------------------------------------------
-- There appear to be few restrictions on how Wikidata is organized so it is
-- very likely that any decision a module makes about how to handle data
-- will be wrong for some cases at some time. This meets current requirements.
-- For each qualifier (or if no qualifier), if there are any preferred
-- statements, use them and ignore any normal statements.
-- For each qualifier, for the preferred statements if any, or for
-- the normal statements (but not both):
-- * Accept each statement if it has no qualifier (this will not occur
-- if qual=x is specified because other code already ensures that in that
-- case, only statements with a qualifier matching x are considered).
-- * Ignore any statements after the first if it has a qualifier.
-- The rationale is that for the diameter at [[South Pole Telescope]], want
-- convert to show the diameters for both the primary and secondary mirrors
-- if the convert does not specify which diameter is wanted.
-- However, if convert is given the wanted qualifier, only one value
-- (_the_ diameter) is wanted. For simplicity/consistency, that is also done
-- even if no qual=x is specified. Unclear what should happen.
-- For the wavelength at [[Nançay Radio Telescope]], want to show all three
-- values, and the values have no qualifiers.
--------------------------------------------------------------------------------
local result = Collection.new()
local done = {}
local skip_normal
for _, t in ipairs(get_statements(parms, pid)) do
local statement = t.stmt
if statement.mainsnak and statement.mainsnak.datatype == 'quantity' then
local value = (statement.mainsnak.datavalue or {}).value
if value then
local amount = value.amount
if amount then
amount = tostring(amount) -- in case amount is ever a number
if amount:sub(1, 1) == '+' then
amount = amount:sub(2)
end
local unit = value.unit
if type(unit) == 'string' then
unit = unit:match('Q%d+$') -- unit item id is at end of URL
local ucode = make_unit(tdata.wikidata_units, parms, unit)
if ucode then
local skip
if t.statqual then
if done[t.statqual] then
skip = true
else
done[t.statqual] = true
end
else
if statement.rank == 'preferred' then
skip_normal = true
elseif skip_normal then
skip = true
end
end
if not skip then
result:add({ amount, ucode })
end
end
end
end
end
end
end
return result
end
local function input_from_text(tdata, parms, text, insert2)
-- Given string should be of form "<value><space><unit>" or
-- "<value1><space>ft<space><value2><space>in" for a special case (feet and inches).
-- Return true if values/units were extracted and inserted, or return nothing.
text = text:gsub(' ', ' '):gsub('%s+', ' ')
local pos = text:find(' ', 1, true)
if pos then
-- Leave checking of value to convert which can handle fractions.
local value = text:sub(1, pos - 1)
local uid = text:sub(pos + 1)
if uid:sub(1, 3) == 'ft ' and uid:sub(-3) == ' in' then
-- Special case for enwiki to allow {{convert|input=5 ft 10+1/2 in}}
insert2(uid:sub(4, -4), 'in')
insert2(value, 'ft')
else
insert2(value, make_unit(tdata.wikidata_units, parms, uid) or uid)
end
return true
end
end
local function adjustparameters(tdata, parms, index)
-- For Module:Convert, adjust parms (a table of {{convert}} parameters).
-- Return true if successful or return false, t where t is an error message table.
-- This is intended mainly for use in infoboxes where the input might be
-- <value><space><unit> or
-- <wikidata-property-id>
-- If successful, insert values and units in parms, before given index.
local text = parms.input -- should be a trimmed, non-empty string
local pid = text:match('^P%d+$')
local sep = ','
local special = specials[parms[index]]
if special then
parms.out_unit = special[1]
sep = special[2] or sep
table.remove(parms, index)
end
local function quit()
return false, pid and { 'cvt_no_output' } or { 'cvt_bad_input', text }
end
local function insert2(first, second)
table.insert(parms, index, second)
table.insert(parms, index, first)
end
if pid then
parms.input_text = '' -- output an empty string if an error occurs
local result = input_from_property(tdata, parms, pid)
if result.n == 0 then
return quit()
end
local ucode
for i, t in ipairs(result) do
-- Convert requires each input unit to be identical.
if i == 1 then
ucode = t[2]
elseif ucode ~= t[2] then
return quit()
end
end
local item = ucode
if item == parms[index] then
-- Remove specified output unit if it is the same as the Wikidata unit.
-- For example, {{convert|input=P2044|km}} with property "12 km".
table.remove(parms, index)
end
for i = result.n, 1, -1 do
insert2(result[i][1], item)
item = sep
end
return true
else
if input_from_text(tdata, parms, text, insert2) then
return true
end
end
return quit()
end
--------------------------------------------------------------------------------
--- List units and check syntax of definitions ---------------------------------
--------------------------------------------------------------------------------
local specifications = {
-- seq = sequence in which fields are displayed
base = {
title = 'SI base units',
fields = {
symbol = { seq = 2, mandatory = true },
name1 = { seq = 3, mandatory = true },
name2 = { seq = 4 },
link = { seq = 5 },
},
noteseq = 6,
header = '{| class="wikitable"\n!si !!symbol !!name1 !!name2 !!link !!note',
item = '|-\n|%s ||%s ||%s ||%s ||%s ||%s',
footer = '|}',
},
alias = {
title = 'Aliases for convert',
fields = {
ucode = { seq = 2, mandatory = true },
si = { seq = 3 },
},
noteseq = 4,
header = '{| class="wikitable"\n!alias !!ucode !!base !!note',
item = '|-\n|%s ||%s ||%s ||%s',
footer = '|}',
},
known = {
title = 'Units known to convert',
fields = {
ucode = { seq = 2, mandatory = true },
label = { seq = 3, mandatory = true },
},
noteseq = 4,
header = '{| class="wikitable"\n!qid !!ucode !!label !!note',
item = '|-\n|%s ||%s ||%s ||%s',
footer = '|}',
},
unknown = {
title = 'Units not known to convert',
fields = {
_ucode = { seq = 2, mandatory = true },
si = { seq = 3 },
name1 = { seq = 4 },
name2 = { seq = 5 },
link = { seq = 6 },
label = { seq = 7, mandatory = true },
},
noteseq = 8,
header = '{| class="wikitable"\n!qid !!_ucode !!base !!name1 !!name2 !!link !!label !!note',
item = '|-\n|%s ||%s ||%s ||%s ||%s ||%s ||%s ||%s',
footer = '|}',
},
}
local function listunits(tdata, ulookup)
-- For Module:Convert, make wikitext to list the built-in Wikidata units.
-- Return true, wikitext if successful or return false, t where t is an
-- error message table. Currently, an error return never occurs.
-- The syntax of each unit definition is checked and a note is added if
-- a problem is detected.
local function safe_cells(t)
-- This is not currently needed, but in case definitions ever use wikitext
-- like '[[kilogram|kg]]', escape the text so it works in a table cell.
local result = {}
for i, v in ipairs(t) do
if v:find('|', 1, true) then
v = v:gsub('(%[%[[^%[%]]-)|(.-%]%])', '%1\0%2') -- replace pipe in piped link with a zero byte
v = v:gsub('|', '|') -- escape '|'
v = v:gsub('%z', '|') -- restore pipe in piped link
end
result[i] = v:gsub('{', '{') -- escape '{'
end
return unpack(result)
end
local wdunits = tdata.wikidata_units
local speckeys = { 'base', 'alias', 'unknown', 'known' }
for _, sid in ipairs(speckeys) do
specifications[sid].units = Collection.new()
end
local keys = Collection.new()
for k, v in pairs(wdunits) do
keys:add(k)
end
table.sort(keys)
local note_count = 0
for _, key in ipairs(keys) do
local unit = wdunits[key]
local ktext, sid
if key:match('^Q%d+$') then
ktext = '[[d:' .. key .. '|' .. key .. ']]'
if unit.ucode then
sid = 'known'
else
sid = 'unknown'
end
elseif unit.ucode then
ktext = key
sid = 'alias'
else
ktext = key
sid = 'base'
end
local result = { ktext }
local spec = specifications[sid]
local fields = spec.fields
local note = Collection.new()
for k, v in pairs(unit) do
if fields[k] then
local seq = fields[k].seq
if result[seq] then
note:add('duplicate ' .. k) -- cannot happen since keys are unique
else
result[seq] = v
end
else
note:add('invalid ' .. k)
end
end
for k, v in pairs(fields) do
local value = result[v.seq]
if value then
if k == 'si' and not wdunits[value] then
note:add('need si ' .. value)
end
if k == 'label' then
local wdl = mw.wikibase.getLabel(key)
if wdl ~= value then
note:add('label changed to ' .. tostring(wdl))
end
end
else
result[v.seq] = ''
if v.mandatory then
note:add('missing ' .. k)
end
end
end
local text
if note.n > 0 then
note_count = note_count + 1
text = '*' .. note:join('<br />')
end
result[spec.noteseq] = text or ''
spec.units:add(result)
end
local results = Collection.new()
if note_count > 0 then
local text = note_count .. (note_count == 1 and ' note' or ' notes')
results:add("'''Search for * to see " .. text .. "'''\n")
end
for _, sid in ipairs(speckeys) do
local spec = specifications[sid]
results:add("'''" .. spec.title .. "'''")
results:add(spec.header)
local fmt = spec.item
for _, unit in ipairs(spec.units) do
results:add(string.format(fmt, safe_cells(unit)))
end
results:add(spec.footer)
end
return true, results:join('\n')
end
return { _adjustparameters = adjustparameters, _listunits = listunits }
b93954acaa7b2c734c1c6f4c869ed6d1821a2d84
Module:Convert/wikidata/data
828
724
1111
2021-06-06T03:21:16Z
wikipedia>Johnuniq
0
update from sandbox per [[Template talk:Convert#Module version 26]]
Scribunto
text/plain
--[[ Cache of Wikidata information with units for Module:Convert.
The codes should rarely change, and using a cache means that changing a
unit at Wikidata will not cause lots of converts in articles to break.
For a unit known to convert, the unit here must have:
label = Wikidata label for unit (used only when listing units)
ucode = unit code for input to convert
(there are no optional fields because convert handles everything)
For a unit not known to convert, the unit here must have:
label = Wikidata label for unit (used only when listing units)
(no ucode field)
_ucode = unit code for input to convert, and the
symbol used to display the unit when abbr=on
(convert will use the specified fields to display the unit,
and will not attempt to do a conversion)
For a unit not known to convert, the unit here may have:
name1 = singular name used to display the unit when abbr=off
name2 = plural name used to display the unit when abbr=off
link = name of article that unit will be linked to when lk=on
si = key for the SI base unit, if any
The base unit for each SI unit here must have:
symbol = symbol used to display the base unit when abbr=on
name1 = singular name of base unit used to display the unit when abbr=off
(if name1 is not given, symbol will be used, but an SI unit should have a name)
The base unit for each SI unit here may have:
name2 = plural name of base unit used to display the unit when abbr=off
link = name of article that unit will be linked to when lk=on
(applies for all SI units using this base, where the
SI unit does not define its own link field)
If name1 is not specified, the symbol is used for the name.
If name2 is not specified, a plural name is formed by appending 's' to name1.
If link is not specified, name1 is used for the link.
SI units are assumed to be simple items like V (volt) where 'mV' would
cause convert to insert:
'm' before the base symbol 'V' to make 'mV', if abbr=on
'milli' before the base name 'volt' to make 'millivolt', if abbr=off
A unit like "square meter" would not work because it needs an SI prefix
inserted before "meter" rather than at the beginning of the name.
Items that should not be used with convert as no precise unit is implied:
Q11247037 ton generic (cannot use)
Q178413 gallon generic
Q130964 calorie dubious (ambiguous, should not use)
Q216658 bushel dubious
Q420266 fluid ounce dubious
]]
local wikidata_units = {
-- Following are SI base units.
A = {
symbol = 'A',
name1 = 'ampere',
},
F = {
symbol = 'F',
name1 = 'faraday',
},
H = {
symbol = 'H',
name1 = 'henry',
},
V = {
symbol = 'V',
name1 = 'volt',
},
-- Following are aliases to convert unit codes, used with "input=<value><space><unit>".
kilograms = {
ucode = 'kg',
},
-- Following are SI units not known to convert, used with "input=<value><space><unit>".
kV = {
ucode = 'kV',
si = 'V',
},
mV = {
ucode = 'mV',
si = 'V',
},
-- Following are Wikidata units.
Q131255 = {
label = 'farad',
_ucode = 'F',
si = 'F',
},
Q163354 = {
label = 'henry',
_ucode = 'H',
si = 'H',
},
Q1916026 = {
label = 'microvolt',
_ucode = 'uV',
si = 'V',
},
Q193933 = {
label = 'dioptre',
name1 = 'dioptre',
_ucode = 'dpt',
},
Q212120 = {
label = 'ampere hour',
name1 = 'ampere hour',
_ucode = 'A⋅h',
},
Q2448803 = {
label = 'millivolt',
_ucode = 'mV',
si = 'V',
},
Q2451296 = {
label = 'microfarad',
_ucode = 'uF',
si = 'F',
},
Q2490574 = {
label = 'milliampere',
_ucode = 'mA',
si = 'A',
},
Q25250 = {
label = 'volt',
_ucode = 'V',
si = 'V',
},
Q25272 = {
label = 'ampere',
_ucode = 'A',
si = 'A',
},
Q2553708 = {
label = 'megavolt',
_ucode = 'MV',
si = 'V',
},
Q2554092 = {
label = 'kilovolt',
_ucode = 'kV',
si = 'V',
},
Q2636421 = {
label = 'nanohenry',
_ucode = 'nH',
si = 'H',
},
Q2679083 = {
label = 'microhenry',
_ucode = 'uH',
si = 'H',
},
Q2682463 = {
label = 'nanofarad',
_ucode = 'nF',
si = 'F',
},
Q2756030 = {
label = 'picofarad',
_ucode = 'pF',
si = 'F',
},
Q2793566 = {
label = 'gigavolt',
_ucode = 'GV',
si = 'V',
},
Q2924137 = {
label = 'millihenry',
_ucode = 'mH',
si = 'H',
},
Q3117809 = {
label = 'microampere',
_ucode = 'uA',
si = 'A',
},
Q33680 = {
label = 'radian',
name1 = 'radian',
_ucode = 'rad',
},
Q4456994 = {
label = 'millifarad',
_ucode = 'mF',
si = 'F',
},
Q47083 = {
label = 'ohm',
name1 = 'ohm',
_ucode = 'Ω',
},
Q483261 = {
label = 'dalton',
name1 = 'dalton',
_ucode = 'u',
},
Q550341 = {
label = 'volt-ampere',
name1 = 'volt-ampere',
_ucode = 'VA',
},
Q100995 = {
label = 'pound',
ucode = 'lb',
},
Q1022113 = {
label = 'cubic centimetre',
ucode = 'cc',
},
Q102573 = {
label = 'becquerel',
ucode = 'Bq',
},
Q103246 = {
label = 'sievert',
ucode = 'Sv',
},
Q1050958 = {
label = 'inch of mercury',
ucode = 'inHg',
},
Q1051665 = {
label = 'metre per second squared',
ucode = 'm/s2',
},
Q1052397 = {
label = 'rad',
ucode = 'rad',
},
Q1054140 = {
label = 'megametre',
ucode = 'Mm',
},
Q1057069 = {
label = 'hectogram',
ucode = 'hg',
},
Q1063786 = {
label = 'square inch',
ucode = 'sqin',
},
Q1092296 = {
label = 'annum',
ucode = 'year',
},
Q11570 = {
label = 'kilogram',
ucode = 'kg',
},
Q11573 = {
label = 'metre',
ucode = 'm',
},
Q11574 = {
label = 'second',
ucode = 's',
},
Q11579 = {
label = 'kelvin',
ucode = 'K',
},
Q11582 = {
label = 'litre',
ucode = 'litre',
},
Q1165588 = {
label = 'rod',
ucode = 'rod',
},
Q1165799 = {
label = 'thou',
ucode = 'thou',
},
Q11776930 = {
label = 'megagram',
ucode = 'Mg',
},
Q11929860 = {
label = 'kiloparsec',
ucode = 'kpc',
},
Q1194225 = {
label = 'pound-force',
ucode = 'lbf',
},
Q12129 = {
label = 'parsec',
ucode = 'pc',
},
Q12438 = {
label = 'newton',
ucode = 'N',
},
Q1255620 = {
label = 'dram',
ucode = 'drachm',
},
Q12874593 = {
label = 'watt-hour',
ucode = 'W.h',
},
Q128822 = {
label = 'knot',
ucode = 'kn',
},
Q1374438 = {
label = 'kilosecond',
ucode = 'ks',
},
Q1377051 = {
label = 'gigasecond',
ucode = 'Gs',
},
Q14754979 = {
label = 'zettagram',
ucode = 'Zg',
},
Q14786969 = {
label = 'megajoule',
ucode = 'MJ',
},
Q14787261 = {
label = 'megawatt hour',
ucode = 'MW.h',
},
Q1550511 = {
label = 'square yard',
ucode = 'sqyd',
},
Q160857 = {
label = 'metric horsepower',
ucode = 'hp',
},
Q1628990 = {
label = 'horsepower-hour',
ucode = 'hph',
},
Q163343 = {
label = 'tesla',
ucode = 'T',
},
Q1645498 = {
label = 'microgram',
ucode = 'ug',
},
Q17087835 = {
label = 'cuerda',
ucode = 'cda',
},
Q174728 = {
label = 'centimetre',
ucode = 'cm',
},
Q174789 = {
label = 'millimetre',
ucode = 'mm',
},
Q175821 = {
label = 'micrometre',
ucode = 'um',
},
Q1770733 = {
label = 'teragram',
ucode = 'Tg',
},
Q1772386 = {
label = 'decigram',
ucode = 'dg',
},
Q177493 = {
label = 'gauss',
ucode = 'G',
},
Q1777507 = {
label = 'femtosecond',
ucode = 'fs',
},
Q177974 = {
label = 'standard atmosphere',
ucode = 'atm',
},
Q178674 = {
label = 'nanometre',
ucode = 'nm',
},
Q180154 = {
label = 'kilometre per hour',
ucode = 'km/h',
},
Q180892 = {
label = 'solar mass',
ucode = 'solar mass',
},
Q1811 = {
label = 'astronomical unit',
ucode = 'au',
},
Q1815100 = {
label = 'centilitre',
ucode = 'cl',
},
Q182098 = {
label = 'kilowatt hour',
ucode = 'kW.h',
},
Q1823150 = {
label = 'microwatt',
ucode = 'uW',
},
Q182429 = {
label = 'metre per second',
ucode = 'm/s',
},
Q1826195 = {
label = 'decilitre',
ucode = 'dl',
},
Q185078 = {
label = 'are',
ucode = 'a',
},
Q185153 = {
label = 'erg',
ucode = 'erg',
},
Q185648 = {
label = 'torr',
ucode = 'Torr',
},
Q190095 = {
label = 'gray',
ucode = 'Gy',
},
Q191118 = {
label = 'tonne',
ucode = 'tonne',
},
Q1913097 = {
label = 'femtogram',
ucode = 'fg',
},
Q192274 = {
label = 'picometre',
ucode = 'pm',
},
Q1972579 = {
label = 'poundal',
ucode = 'pdl',
},
Q200323 = {
label = 'decimetre',
ucode = 'dm',
},
Q201933 = {
label = 'dyne',
ucode = 'dyn',
},
Q2029519 = {
label = 'hectolitre',
ucode = 'hl',
},
Q2051195 = {
label = 'gigawatt hour',
ucode = 'GW.h',
},
Q207488 = {
label = 'Rankine scale',
ucode = 'R',
},
Q208788 = {
label = 'femtometre',
ucode = 'fm',
},
Q2101 = {
label = 'elementary charge',
ucode = 'e',
},
Q21014455 = {
label = 'metre per minute',
ucode = 'm/min',
},
Q21062777 = {
label = 'megapascal',
ucode = 'MPa',
},
Q21064807 = {
label = 'kilopascal',
ucode = 'kPa',
},
Q211256 = {
label = 'mile per hour',
ucode = 'mph',
},
Q21178489 = {
label = 'barrels per day',
ucode = 'oilbbl/d',
},
Q2143992 = {
label = 'kilohertz',
ucode = 'kHz',
},
Q21467992 = {
label = 'cubic foot per second',
ucode = 'cuft/s',
},
Q215571 = {
label = 'newton metre',
ucode = 'Nm',
},
Q216795 = {
label = 'dunam',
ucode = 'dunam',
},
Q216880 = {
label = 'kilogram-force',
ucode = 'kgf',
},
Q18413919 = {
label = 'centimetre per second',
ucode = 'cm/s',
},
Q218593 = {
label = 'inch',
ucode = 'in',
},
Q2282891 = {
label = 'microlitre',
ucode = 'ul',
},
Q2282906 = {
label = 'nanogram',
ucode = 'ng',
},
Q229354 = {
label = 'curie',
ucode = 'Ci',
},
Q232291 = {
label = 'square mile',
ucode = 'sqmi',
},
Q2332346 = {
label = 'millilitre',
ucode = 'ml',
},
Q23387 = {
label = 'week',
ucode = 'week',
},
Q23823681 = {
label = 'terawatt',
ucode = 'TW',
},
Q23925410 = {
label = 'gallon (UK)',
ucode = 'impgal',
},
Q23925413 = {
label = 'gallon (US)',
ucode = 'USgal',
},
Q2438073 = {
label = 'attogram',
ucode = 'ag',
},
Q2474258 = {
label = 'millisievert',
ucode = 'mSv',
},
Q2483628 = {
label = 'attosecond',
ucode = 'as',
},
Q2489298 = {
label = 'square centimetre',
ucode = 'cm2',
},
Q2518569 = {
label = 'nanosievert',
ucode = 'nSv',
},
Q25235 = {
label = 'hour',
ucode = 'h',
},
Q25236 = {
label = 'watt',
ucode = 'W',
},
Q25267 = {
label = 'degree Celsius',
ucode = 'C',
},
Q25269 = {
label = 'joule',
ucode = 'J',
},
Q253276 = {
label = 'mile',
ucode = 'mi',
},
Q25343 = {
label = 'square metre',
ucode = 'm2',
},
Q25406 = {
label = 'coulomb',
ucode = 'coulomb',
},
Q25517 = {
label = 'cubic metre',
ucode = 'm3',
},
Q260126 = {
label = 'Roentgen equivalent man',
ucode = 'rem',
},
Q2612219 = {
label = 'petagram',
ucode = 'Pg',
},
Q2619500 = {
label = 'foe',
ucode = 'foe',
},
Q2637946 = {
label = 'decalitre',
ucode = 'dal',
},
Q2655272 = {
label = 'exagram',
ucode = 'Eg',
},
Q2691798 = {
label = 'centigram',
ucode = 'cg',
},
Q2739114 = {
label = 'microsievert',
ucode = 'uSv',
},
Q2799294 = {
label = 'gigagram',
ucode = 'Gg',
},
Q3013059 = {
label = 'kiloannum',
ucode = 'millennium',
},
Q305896 = {
label = 'dots per inch',
ucode = 'dpi',
},
Q3207456 = {
label = 'milliwatt',
ucode = 'mW',
},
Q3221356 = {
label = 'yoctometre',
ucode = 'ym',
},
Q3239557 = {
label = 'picogram',
ucode = 'pg',
},
Q3241121 = {
label = 'milligram',
ucode = 'mg',
},
Q3267417 = {
label = 'terametre',
ucode = 'Tm',
},
Q3270676 = {
label = 'zeptometre',
ucode = 'zm',
},
Q3276763 = {
label = 'gigahertz',
ucode = 'GHz',
},
Q3277907 = {
label = 'exametre',
ucode = 'Em',
},
Q3277915 = {
label = 'zettametre',
ucode = 'Zm',
},
Q3277919 = {
label = 'petametre',
ucode = 'Pm',
},
Q3312063 = {
label = 'femtolitre',
ucode = 'fl',
},
Q3320608 = {
label = 'kilowatt',
ucode = 'kW',
},
Q3332822 = {
label = 'megaton of TNT',
ucode = 'Mt(TNT)',
},
Q35852 = {
label = 'hectare',
ucode = 'ha',
},
Q3675550 = {
label = 'cubic millimetre',
ucode = 'mm3',
},
Q3710 = {
label = 'foot',
ucode = 'ft',
},
Q3773454 = {
label = 'megaparsec',
ucode = 'Mpc',
},
Q3902688 = {
label = 'picolitre',
ucode = 'pl',
},
Q3902709 = {
label = 'picosecond',
ucode = 'ps',
},
Q39369 = {
label = 'hertz',
ucode = 'Hz',
},
Q3972226 = {
label = 'kilolitre',
ucode = 'kl',
},
Q4068266 = {
label = "apothecaries' drachm",
ucode = 'drachm',
},
Q41803 = {
label = 'gram',
ucode = 'g',
},
Q4220561 = {
label = 'kilometre per second',
ucode = 'km/s',
},
Q42289 = {
label = 'degree Fahrenheit',
ucode = 'F',
},
Q4243638 = {
label = 'cubic kilometre',
ucode = 'km3',
},
Q44395 = {
label = 'pascal',
ucode = 'Pa',
},
Q48013 = {
label = 'ounce',
ucode = 'oz',
},
Q482798 = {
label = 'yard',
ucode = 'yd',
},
Q4989854 = {
label = 'kilojoule',
ucode = 'kJ',
},
Q4992853 = {
label = 'kiloton of TNT',
ucode = 'kt(TNT)',
},
Q5139563 = {
label = 'hectopascal',
ucode = 'hPa',
},
Q5151 = {
label = 'month',
ucode = 'month',
},
Q531 = {
label = 'light-year',
ucode = 'ly',
},
Q5465723 = {
label = 'foot-poundal',
ucode = 'ftpdl',
},
Q573 = {
label = 'day',
ucode = 'd',
},
Q577 = {
label = 'year',
ucode = 'year',
},
Q5879479 = {
label = 'gigawatt',
ucode = 'GW',
},
Q6003257 = {
label = 'attometre',
ucode = 'am',
},
Q613726 = {
label = 'yottagram',
ucode = 'Yg',
},
Q6170164 = {
label = 'yoctogram',
ucode = 'yg',
},
Q667419 = {
label = 'long ton',
ucode = 'LT',
},
Q673166 = {
label = 'gravity of Earth',
ucode = 'g0',
},
Q693944 = {
label = 'grain',
ucode = 'gr',
},
Q6982035 = {
label = 'megawatt',
ucode = 'MW',
},
Q712226 = {
label = 'square kilometre',
ucode = 'km2',
},
Q723733 = {
label = 'millisecond',
ucode = 'ms',
},
Q732454 = {
label = 'megaannum',
ucode = 'Myr',
},
Q732707 = {
label = 'megahertz',
ucode = 'MHz',
},
Q752079 = {
label = 'gross register ton',
ucode = 'grt',
},
Q752197 = {
label = 'kilojoule per mole',
ucode = 'kJ/mol',
},
Q7727 = {
label = 'minute',
ucode = 'min',
},
Q794261 = {
label = 'cubic metre per second',
ucode = 'm3/s',
},
Q809678 = {
label = 'barye',
ucode = 'Ba',
},
Q81292 = {
label = 'acre',
ucode = 'acre',
},
Q81454 = {
label = 'ångström',
ucode = 'angstrom',
},
Q828224 = {
label = 'kilometre',
ucode = 'km',
},
Q83327 = {
label = 'electronvolt',
ucode = 'eV',
},
Q838801 = {
label = 'nanosecond',
ucode = 'ns',
},
Q842015 = {
label = 'microsecond',
ucode = 'us',
},
Q844211 = {
label = 'kilogram per cubic metre',
ucode = 'kg/m3',
},
Q844338 = {
label = 'hectometre',
ucode = 'hm',
},
Q844976 = {
label = 'oersted',
ucode = 'Oe',
},
Q848856 = {
label = 'decametre',
ucode = 'dam',
},
Q854546 = {
label = 'gigametre',
ucode = 'Gm',
},
Q857027 = {
label = 'square foot',
ucode = 'sqft',
},
Q9048643 = {
label = 'nanolitre',
ucode = 'nl',
},
Q93318 = {
label = 'nautical mile',
ucode = 'nmi',
},
}
return { wikidata_units = wikidata_units }
780312bf04e64ca1dd5fb2b59dc26b420a30ab56
Template:About
10
311
447
2021-09-16T00:56:50Z
wikipedia>Wbm1058
0
should implement in [[Module:About]]. Piped {{!}} links causing false positives.
wikitext
text/x-wiki
{{#invoke:about|about}}<noinclude>
{{Documentation}}
</noinclude>
34b07e47d9b8220bf56dd9882945ad464b21a731
Module:Unsubst
828
730
1123
2021-10-08T18:22:16Z
wikipedia>Trappist the monk
0
sync from sandbox; see [[Module_talk:Unsubst#template_invocation_name_override|talk]];
Scribunto
text/plain
local checkType = require('libraryUtil').checkType
local p = {}
local BODY_PARAM = '$B'
local specialParams = {
['$params'] = 'parameter list',
['$aliases'] = 'parameter aliases',
['$flags'] = 'flags',
['$B'] = 'template content',
['$template-name'] = 'template invocation name override',
}
function p.main(frame, body)
-- If we are substing, this function returns a template invocation, and if
-- not, it returns the template body. The template body can be specified in
-- the body parameter, or in the template parameter defined in the
-- BODY_PARAM variable. This function can be called from Lua or from
-- #invoke.
-- Return the template body if we aren't substing.
if not mw.isSubsting() then
if body ~= nil then
return body
elseif frame.args[BODY_PARAM] ~= nil then
return frame.args[BODY_PARAM]
else
error(string.format(
"no template content specified (use parameter '%s' from #invoke)",
BODY_PARAM
), 2)
end
end
-- Sanity check for the frame object.
if type(frame) ~= 'table'
or type(frame.getParent) ~= 'function'
or not frame:getParent()
then
error(
"argument #1 to 'main' must be a frame object with a parent " ..
"frame available",
2
)
end
-- Find the invocation name.
local mTemplateInvocation = require('Module:Template invocation')
local name
if frame.args['$template-name'] and '' ~= frame.args['$template-name'] then
name = frame.args['$template-name'] -- override whatever the template name is with this name
else
name = mTemplateInvocation.name(frame:getParent():getTitle())
end
-- Combine passed args with passed defaults
local args = {}
if string.find( ','..(frame.args['$flags'] or '')..',', ',%s*override%s*,' ) then
for k, v in pairs( frame:getParent().args ) do
args[k] = v
end
for k, v in pairs( frame.args ) do
if not specialParams[k] then
if v == '__DATE__' then
v = mw.getContentLanguage():formatDate( 'F Y' )
end
args[k] = v
end
end
else
for k, v in pairs( frame.args ) do
if not specialParams[k] then
if v == '__DATE__' then
v = mw.getContentLanguage():formatDate( 'F Y' )
end
args[k] = v
end
end
for k, v in pairs( frame:getParent().args ) do
args[k] = v
end
end
-- Trim parameters, if not specified otherwise
if not string.find( ','..(frame.args['$flags'] or '')..',', ',%s*keep%-whitespace%s*,' ) then
for k, v in pairs( args ) do args[k] = mw.ustring.match(v, '^%s*(.*)%s*$') or '' end
end
-- Pull information from parameter aliases
local aliases = {}
if frame.args['$aliases'] then
local list = mw.text.split( frame.args['$aliases'], '%s*,%s*' )
for k, v in ipairs( list ) do
local tmp = mw.text.split( v, '%s*>%s*' )
aliases[tonumber(mw.ustring.match(tmp[1], '^[1-9][0-9]*$')) or tmp[1]] = ((tonumber(mw.ustring.match(tmp[2], '^[1-9][0-9]*$'))) or tmp[2])
end
end
for k, v in pairs( aliases ) do
if args[k] and ( not args[v] or args[v] == '' ) then
args[v] = args[k]
end
args[k] = nil
end
-- Remove empty parameters, if specified
if string.find( ','..(frame.args['$flags'] or '')..',', ',%s*remove%-empty%s*,' ) then
local tmp = 0
for k, v in ipairs( args ) do
if v ~= '' or ( args[k+1] and args[k+1] ~= '' ) or ( args[k+2] and args[k+2] ~= '' ) then
tmp = k
else
break
end
end
for k, v in pairs( args ) do
if v == '' then
if not (type(k) == 'number' and k < tmp) then args[k] = nil end
end
end
end
-- Order parameters
if frame.args['$params'] then
local params, tmp = mw.text.split( frame.args['$params'], '%s*,%s*' ), {}
for k, v in ipairs(params) do
v = tonumber(mw.ustring.match(v, '^[1-9][0-9]*$')) or v
if args[v] then tmp[v], args[v] = args[v], nil end
end
for k, v in pairs(args) do tmp[k], args[k] = args[k], nil end
args = tmp
end
return mTemplateInvocation.invocation(name, args)
end
p[''] = p.main -- For backwards compatibility
return p
7f01ffc8aa2ac4a4772f14c12e0b77e384ecabb6
Module:Format link
828
336
439
2022-10-04T13:37:11Z
wikipedia>Pppery
0
Avoid Lua erroring when we run out of expensive parser function calls
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Format link
--
-- Makes a wikilink from the given link and display values. Links are escaped
-- with colons if necessary, and links to sections are detected and displayed
-- with " § " as a separator rather than the standard MediaWiki "#". Used in
-- the {{format link}} template.
--------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local checkTypeForNamedArg = libraryUtil.checkTypeForNamedArg
local mArguments -- lazily initialise [[Module:Arguments]]
local mError -- lazily initialise [[Module:Error]]
local yesno -- lazily initialise [[Module:Yesno]]
local p = {}
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
local function getArgs(frame)
-- Fetches the arguments from the parent frame. Whitespace is trimmed and
-- blanks are removed.
mArguments = require('Module:Arguments')
return mArguments.getArgs(frame, {parentOnly = true})
end
local function removeInitialColon(s)
-- Removes the initial colon from a string, if present.
return s:match('^:?(.*)')
end
local function maybeItalicize(s, shouldItalicize)
-- Italicize s if s is a string and the shouldItalicize parameter is true.
if s and shouldItalicize then
return '<i>' .. s .. '</i>'
else
return s
end
end
local function parseLink(link)
-- Parse a link and return a table with the link's components.
-- These components are:
-- - link: the link, stripped of any initial colon (always present)
-- - page: the page name (always present)
-- - section: the page name (may be nil)
-- - display: the display text, if manually entered after a pipe (may be nil)
link = removeInitialColon(link)
-- Find whether a faux display value has been added with the {{!}} magic
-- word.
local prePipe, display = link:match('^(.-)|(.*)$')
link = prePipe or link
-- Find the page, if it exists.
-- For links like [[#Bar]], the page will be nil.
local preHash, postHash = link:match('^(.-)#(.*)$')
local page
if not preHash then
-- We have a link like [[Foo]].
page = link
elseif preHash ~= '' then
-- We have a link like [[Foo#Bar]].
page = preHash
end
-- Find the section, if it exists.
local section
if postHash and postHash ~= '' then
section = postHash
end
return {
link = link,
page = page,
section = section,
display = display,
}
end
local function formatDisplay(parsed, options)
-- Formats a display string based on a parsed link table (matching the
-- output of parseLink) and an options table (matching the input options for
-- _formatLink).
local page = maybeItalicize(parsed.page, options.italicizePage)
local section = maybeItalicize(parsed.section, options.italicizeSection)
if (not section) then
return page
elseif (not page) then
return mw.ustring.format('§ %s', section)
else
return mw.ustring.format('%s § %s', page, section)
end
end
local function missingArgError(target)
mError = require('Module:Error')
return mError.error{message =
'Error: no link or target specified! ([[' .. target .. '#Errors|help]])'
}
end
--------------------------------------------------------------------------------
-- Main functions
--------------------------------------------------------------------------------
function p.formatLink(frame)
-- The formatLink export function, for use in templates.
yesno = require('Module:Yesno')
local args = getArgs(frame)
local link = args[1] or args.link
local target = args[3] or args.target
if not (link or target) then
return missingArgError('Template:Format link')
end
return p._formatLink{
link = link,
display = args[2] or args.display,
target = target,
italicizePage = yesno(args.italicizepage),
italicizeSection = yesno(args.italicizesection),
categorizeMissing = args.categorizemissing
}
end
function p._formatLink(options)
-- The formatLink export function, for use in modules.
checkType('_formatLink', 1, options, 'table')
local function check(key, expectedType) --for brevity
checkTypeForNamedArg(
'_formatLink', key, options[key], expectedType or 'string', true
)
end
check('link')
check('display')
check('target')
check('italicizePage', 'boolean')
check('italicizeSection', 'boolean')
check('categorizeMissing')
-- Normalize link and target and check that at least one is present
if options.link == '' then options.link = nil end
if options.target == '' then options.target = nil end
if not (options.link or options.target) then
return missingArgError('Module:Format link')
end
local parsed = parseLink(options.link)
local display = options.display or parsed.display
local catMissing = options.categorizeMissing
local category = ''
-- Find the display text
if not display then display = formatDisplay(parsed, options) end
-- Handle the target option if present
if options.target then
local parsedTarget = parseLink(options.target)
parsed.link = parsedTarget.link
parsed.page = parsedTarget.page
end
-- Test if page exists if a diagnostic category is specified
if catMissing and (mw.ustring.len(catMissing) > 0) then
local title = nil
if parsed.page then title = mw.title.new(parsed.page) end
if title and (not title.isExternal) then
local success, exists = pcall(function() return title.exists end)
if success and not exists then
category = mw.ustring.format('[[Category:%s]]', catMissing)
end
end
end
-- Format the result as a link
if parsed.link == display then
return mw.ustring.format('[[:%s]]%s', parsed.link, category)
else
return mw.ustring.format('[[:%s|%s]]%s', parsed.link, display, category)
end
end
--------------------------------------------------------------------------------
-- Derived convenience functions
--------------------------------------------------------------------------------
function p.formatPages(options, pages)
-- Formats an array of pages using formatLink and the given options table,
-- and returns it as an array. Nil values are not allowed.
local ret = {}
for i, page in ipairs(pages) do
ret[i] = p._formatLink{
link = page,
categorizeMissing = options.categorizeMissing,
italicizePage = options.italicizePage,
italicizeSection = options.italicizeSection
}
end
return ret
end
return p
1253bdd2683ee4badc33856bfd5499b09a7dca1f
Template:Hlist/styles.css
10
827
1283
2022-12-26T18:00:17Z
wikipedia>Izno
0
actually remove that block, someone can dig for authorship
sanitized-css
text/css
/* {{pp-protected|reason=match parent|small=yes}} */
/*
* hlist styles are defined in core and Minerva and differ in Minerva. The
* current definitions here (2023-01-01) are sufficient to override Minerva
* without use of the hlist-separated class. The most problematic styles were
* related to margin, padding, and the bullet. Check files listed at
* [[MediaWiki talk:Common.css/to do#hlist-separated]]
*/
/*
* TODO: When the majority of readership supports it (or some beautiful world
* in which grade C support is above the minimum threshold), use :is()
*/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so:
*.hlist dt:not(:last-child)::after {
* content: ": ";
*}
*.hlist dd:not(:last-child)::after,
*.hlist li:not(:last-child)::after {
* content: " · ";
* font-weight: bold;
*}
*/
/* Generate interpuncts */
.hlist dt::after {
content: ": ";
}
.hlist dd::after,
.hlist li::after {
content: " · ";
font-weight: bold;
}
.hlist dd:last-child::after,
.hlist dt:last-child::after,
.hlist li:last-child::after {
content: none;
}
/* Add parentheses around nested lists */
.hlist dd dd:first-child::before,
.hlist dd dt:first-child::before,
.hlist dd li:first-child::before,
.hlist dt dd:first-child::before,
.hlist dt dt:first-child::before,
.hlist dt li:first-child::before,
.hlist li dd:first-child::before,
.hlist li dt:first-child::before,
.hlist li li:first-child::before {
content: " (";
font-weight: normal;
}
.hlist dd dd:last-child::after,
.hlist dd dt:last-child::after,
.hlist dd li:last-child::after,
.hlist dt dd:last-child::after,
.hlist dt dt:last-child::after,
.hlist dt li:last-child::after,
.hlist li dd:last-child::after,
.hlist li dt:last-child::after,
.hlist li li:last-child::after {
content: ")";
font-weight: normal;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) "\a0";
}
.hlist dd ol > li:first-child::before,
.hlist dt ol > li:first-child::before,
.hlist li ol > li:first-child::before {
content: " (" counter(listitem) "\a0";
}
8c9dd9c9c00f30eead17fe10f51d183333e81f33
Module:ConvertNumeric
828
726
1115
2023-02-09T01:04:17Z
wikipedia>Johnuniq
0
please don't use tricky syntax: stick to boring stuff that works
Scribunto
text/plain
-- Module for converting between different representations of numbers. See talk page for user documentation.
-- For unit tests see: [[Module:ConvertNumeric/testcases]]
-- When editing, preview with: [[Module_talk:ConvertNumeric/testcases]]
-- First, edit [[Module:ConvertNumeric/sandbox]], then preview with [[Module_talk:ConvertNumeric/sandbox/testcases]]
require('strict')
local ones_position = {
[0] = 'zero',
[1] = 'one',
[2] = 'two',
[3] = 'three',
[4] = 'four',
[5] = 'five',
[6] = 'six',
[7] = 'seven',
[8] = 'eight',
[9] = 'nine',
[10] = 'ten',
[11] = 'eleven',
[12] = 'twelve',
[13] = 'thirteen',
[14] = 'fourteen',
[15] = 'fifteen',
[16] = 'sixteen',
[17] = 'seventeen',
[18] = 'eighteen',
[19] = 'nineteen'
}
local ones_position_ord = {
[0] = 'zeroth',
[1] = 'first',
[2] = 'second',
[3] = 'third',
[4] = 'fourth',
[5] = 'fifth',
[6] = 'sixth',
[7] = 'seventh',
[8] = 'eighth',
[9] = 'ninth',
[10] = 'tenth',
[11] = 'eleventh',
[12] = 'twelfth',
[13] = 'thirteenth',
[14] = 'fourteenth',
[15] = 'fifteenth',
[16] = 'sixteenth',
[17] = 'seventeenth',
[18] = 'eighteenth',
[19] = 'nineteenth'
}
local ones_position_plural = {
[0] = 'zeros',
[1] = 'ones',
[2] = 'twos',
[3] = 'threes',
[4] = 'fours',
[5] = 'fives',
[6] = 'sixes',
[7] = 'sevens',
[8] = 'eights',
[9] = 'nines',
[10] = 'tens',
[11] = 'elevens',
[12] = 'twelves',
[13] = 'thirteens',
[14] = 'fourteens',
[15] = 'fifteens',
[16] = 'sixteens',
[17] = 'seventeens',
[18] = 'eighteens',
[19] = 'nineteens'
}
local tens_position = {
[2] = 'twenty',
[3] = 'thirty',
[4] = 'forty',
[5] = 'fifty',
[6] = 'sixty',
[7] = 'seventy',
[8] = 'eighty',
[9] = 'ninety'
}
local tens_position_ord = {
[2] = 'twentieth',
[3] = 'thirtieth',
[4] = 'fortieth',
[5] = 'fiftieth',
[6] = 'sixtieth',
[7] = 'seventieth',
[8] = 'eightieth',
[9] = 'ninetieth'
}
local tens_position_plural = {
[2] = 'twenties',
[3] = 'thirties',
[4] = 'forties',
[5] = 'fifties',
[6] = 'sixties',
[7] = 'seventies',
[8] = 'eighties',
[9] = 'nineties'
}
local groups = {
[1] = 'thousand',
[2] = 'million',
[3] = 'billion',
[4] = 'trillion',
[5] = 'quadrillion',
[6] = 'quintillion',
[7] = 'sextillion',
[8] = 'septillion',
[9] = 'octillion',
[10] = 'nonillion',
[11] = 'decillion',
[12] = 'undecillion',
[13] = 'duodecillion',
[14] = 'tredecillion',
[15] = 'quattuordecillion',
[16] = 'quindecillion',
[17] = 'sexdecillion',
[18] = 'septendecillion',
[19] = 'octodecillion',
[20] = 'novemdecillion',
[21] = 'vigintillion',
[22] = 'unvigintillion',
[23] = 'duovigintillion',
[24] = 'tresvigintillion',
[25] = 'quattuorvigintillion',
[26] = 'quinquavigintillion',
[27] = 'sesvigintillion',
[28] = 'septemvigintillion',
[29] = 'octovigintillion',
[30] = 'novemvigintillion',
[31] = 'trigintillion',
[32] = 'untrigintillion',
[33] = 'duotrigintillion',
[34] = 'trestrigintillion',
[35] = 'quattuortrigintillion',
[36] = 'quinquatrigintillion',
[37] = 'sestrigintillion',
[38] = 'septentrigintillion',
[39] = 'octotrigintillion',
[40] = 'noventrigintillion',
[41] = 'quadragintillion',
[51] = 'quinquagintillion',
[61] = 'sexagintillion',
[71] = 'septuagintillion',
[81] = 'octogintillion',
[91] = 'nonagintillion',
[101] = 'centillion',
[102] = 'uncentillion',
[103] = 'duocentillion',
[104] = 'trescentillion',
[111] = 'decicentillion',
[112] = 'undecicentillion',
[121] = 'viginticentillion',
[122] = 'unviginticentillion',
[131] = 'trigintacentillion',
[141] = 'quadragintacentillion',
[151] = 'quinquagintacentillion',
[161] = 'sexagintacentillion',
[171] = 'septuagintacentillion',
[181] = 'octogintacentillion',
[191] = 'nonagintacentillion',
[201] = 'ducentillion',
[301] = 'trecentillion',
[401] = 'quadringentillion',
[501] = 'quingentillion',
[601] = 'sescentillion',
[701] = 'septingentillion',
[801] = 'octingentillion',
[901] = 'nongentillion',
[1001] = 'millinillion',
}
local roman_numerals = {
I = 1,
V = 5,
X = 10,
L = 50,
C = 100,
D = 500,
M = 1000
}
local engord_tens_end = {
['twentieth'] = 20,
['thirtieth'] = 30,
['fortieth'] = 40,
['fiftieth'] = 50,
['sixtieth'] = 60,
['seventieth'] = 70,
['eightieth'] = 80,
['ninetieth'] = 90,
}
local eng_tens_cont = {
['twenty'] = 20,
['thirty'] = 30,
['forty'] = 40,
['fifty'] = 50,
['sixty'] = 60,
['seventy'] = 70,
['eighty'] = 80,
['ninety'] = 90,
}
-- Converts a given valid roman numeral (and some invalid roman numerals) to a number. Returns { -1, errorstring } on error.
local function roman_to_numeral(roman)
if type(roman) ~= "string" then return -1, "roman numeral not a string" end
local rev = roman:reverse()
local raising = true
local last = 0
local result = 0
for i = 1, #rev do
local c = rev:sub(i, i)
local next = roman_numerals[c]
if next == nil then return -1, "roman numeral contains illegal character " .. c end
if next > last then
result = result + next
raising = true
elseif next < last then
result = result - next
raising = false
elseif raising then
result = result + next
else
result = result - next
end
last = next
end
return result
end
-- Converts a given integer between 0 and 100 to English text (e.g. 47 -> forty-seven).
local function numeral_to_english_less_100(num, ordinal, plural, zero)
local terminal_ones, terminal_tens
if ordinal then
terminal_ones = ones_position_ord
terminal_tens = tens_position_ord
elseif plural then
terminal_ones = ones_position_plural
terminal_tens = tens_position_plural
else
terminal_ones = ones_position
terminal_tens = tens_position
end
if num == 0 and zero ~= nil then
return zero
elseif num < 20 then
return terminal_ones[num]
elseif num % 10 == 0 then
return terminal_tens[num / 10]
else
return tens_position[math.floor(num / 10)] .. '-' .. terminal_ones[num % 10]
end
end
local function standard_suffix(ordinal, plural)
if ordinal then return 'th' end
if plural then return 's' end
return ''
end
-- Converts a given integer (in string form) between 0 and 1000 to English text (e.g. 47 -> forty-seven).
local function numeral_to_english_less_1000(num, use_and, ordinal, plural, zero)
num = tonumber(num)
if num < 100 then
return numeral_to_english_less_100(num, ordinal, plural, zero)
elseif num % 100 == 0 then
return ones_position[num/100] .. ' hundred' .. standard_suffix(ordinal, plural)
else
return ones_position[math.floor(num/100)] .. ' hundred ' .. (use_and and 'and ' or '') .. numeral_to_english_less_100(num % 100, ordinal, plural, zero)
end
end
-- Converts an ordinal in English text from 'zeroth' to 'ninety-ninth' inclusive to a number [0–99], else -1.
local function english_to_ordinal(english)
local eng = string.lower(english or '')
local engord_lt20 = {} -- ones_position_ord{} keys & values swapped
for k, v in pairs( ones_position_ord ) do
engord_lt20[v] = k
end
if engord_lt20[eng] then
return engord_lt20[eng] -- e.g. first -> 1
elseif engord_tens_end[eng] then
return engord_tens_end[eng] -- e.g. ninetieth -> 90
else
local tens, ones = string.match(eng, '^([a-z]+)[%s%-]+([a-z]+)$')
if tens and ones then
local tens_cont = eng_tens_cont[tens]
local ones_end = engord_lt20[ones]
if tens_cont and ones_end then
return tens_cont + ones_end -- e.g. ninety-ninth -> 99
end
end
end
return -1 -- Failed
end
-- Converts a number in English text from 'zero' to 'ninety-nine' inclusive to a number [0–99], else -1.
local function english_to_numeral(english)
local eng = string.lower(english or '')
local eng_lt20 = { ['single'] = 1 } -- ones_position{} keys & values swapped
for k, v in pairs( ones_position ) do
eng_lt20[v] = k
end
if eng_lt20[eng] then
return eng_lt20[eng] -- e.g. one -> 1
elseif eng_tens_cont[eng] then
return eng_tens_cont[eng] -- e.g. ninety -> 90
else
local tens, ones = string.match(eng, '^([a-z]+)[%s%-]+([a-z]+)$')
if tens and ones then
local tens_cont = eng_tens_cont[tens]
local ones_end = eng_lt20[ones]
if tens_cont and ones_end then
return tens_cont + ones_end -- e.g. ninety-nine -> 99
end
end
end
return -1 -- Failed
end
-- Converts a number expressed as a string in scientific notation to a string in standard decimal notation
-- e.g. 1.23E5 -> 123000, 1.23E-5 = .0000123. Conversion is exact, no rounding is performed.
local function scientific_notation_to_decimal(num)
local exponent, subs = num:gsub("^%-?%d*%.?%d*%-?[Ee]([+%-]?%d+)$", "%1")
if subs == 0 then return num end -- Input not in scientific notation, just return unmodified
exponent = tonumber(exponent)
local negative = num:find("^%-")
local _, decimal_pos = num:find("%.")
-- Mantissa will consist of all decimal digits with no decimal point
local mantissa = num:gsub("^%-?(%d*)%.?(%d*)%-?[Ee][+%-]?%d+$", "%1%2")
if negative and decimal_pos then decimal_pos = decimal_pos - 1 end
if not decimal_pos then decimal_pos = #mantissa + 1 end
-- Remove leading zeros unless decimal point is in first position
while decimal_pos > 1 and mantissa:sub(1,1) == '0' do
mantissa = mantissa:sub(2)
decimal_pos = decimal_pos - 1
end
-- Shift decimal point right for exponent > 0
while exponent > 0 do
decimal_pos = decimal_pos + 1
exponent = exponent - 1
if decimal_pos > #mantissa + 1 then mantissa = mantissa .. '0' end
-- Remove leading zeros unless decimal point is in first position
while decimal_pos > 1 and mantissa:sub(1,1) == '0' do
mantissa = mantissa:sub(2)
decimal_pos = decimal_pos - 1
end
end
-- Shift decimal point left for exponent < 0
while exponent < 0 do
if decimal_pos == 1 then
mantissa = '0' .. mantissa
else
decimal_pos = decimal_pos - 1
end
exponent = exponent + 1
end
-- Insert decimal point in correct position and return
return (negative and '-' or '') .. mantissa:sub(1, decimal_pos - 1) .. '.' .. mantissa:sub(decimal_pos)
end
-- Rounds a number to the nearest integer (NOT USED)
local function round_num(x)
if x%1 >= 0.5 then
return math.ceil(x)
else
return math.floor(x)
end
end
-- Rounds a number to the nearest two-word number (round = up, down, or "on" for round to nearest).
-- Numbers with two digits before the decimal will be rounded to an integer as specified by round.
-- Larger numbers will be rounded to a number with only one nonzero digit in front and all other digits zero.
-- Negative sign is preserved and does not count towards word limit.
local function round_for_english(num, round)
-- If an integer with at most two digits, just return
if num:find("^%-?%d?%d%.?$") then return num end
local negative = num:find("^%-")
if negative then
-- We're rounding magnitude so flip it
if round == 'up' then round = 'down' elseif round == 'down' then round = 'up' end
end
-- If at most two digits before decimal, round to integer and return
local _, _, small_int, trailing_digits, round_digit = num:find("^%-?(%d?%d?)%.((%d)%d*)$")
if small_int then
if small_int == '' then small_int = '0' end
if (round == 'up' and trailing_digits:find('[1-9]')) or (round == 'on' and tonumber(round_digit) >= 5) then
small_int = tostring(tonumber(small_int) + 1)
end
return (negative and '-' or '') .. small_int
end
-- When rounding up, any number with > 1 nonzero digit will round up (e.g. 1000000.001 rounds up to 2000000)
local nonzero_digits = 0
for digit in num:gfind("[1-9]") do
nonzero_digits = nonzero_digits + 1
end
num = num:gsub("%.%d*$", "") -- Remove decimal part
-- Second digit used to determine which way to round lead digit
local _, _, lead_digit, round_digit, round_digit_2, rest = num:find("^%-?(%d)(%d)(%d)(%d*)$")
if tonumber(lead_digit .. round_digit) < 20 and (1 + #rest) % 3 == 0 then
-- In English numbers < 20 are one word so put 2 digits in lead and round based on 3rd
lead_digit = lead_digit .. round_digit
round_digit = round_digit_2
else
rest = round_digit_2 .. rest
end
if (round == 'up' and nonzero_digits > 1) or (round == 'on' and tonumber(round_digit) >= 5) then
lead_digit = tostring(tonumber(lead_digit) + 1)
end
-- All digits but lead digit will turn to zero
rest = rest:gsub("%d", "0")
return (negative and '-' or '') .. lead_digit .. '0' .. rest
end
local denominators = {
[2] = { 'half', plural = 'halves' },
[3] = { 'third' },
[4] = { 'quarter', us = 'fourth' },
[5] = { 'fifth' },
[6] = { 'sixth' },
[8] = { 'eighth' },
[9] = { 'ninth' },
[10] = { 'tenth' },
[16] = { 'sixteenth' },
}
-- Return status, fraction where:
-- status is a string:
-- "finished" if there is a fraction with no whole number;
-- "ok" if fraction is empty or valid;
-- "unsupported" if bad fraction;
-- fraction is a string giving (numerator / denominator) as English text, or is "".
-- Only unsigned fractions with a very limited range of values are supported,
-- except that if whole is empty, the numerator can use "-" to indicate negative.
-- whole (string or nil): nil or "" if no number before the fraction
-- numerator (string or nil): numerator, if any (default = 1 if a denominator is given)
-- denominator (string or nil): denominator, if any
-- sp_us (boolean): true if sp=us
-- negative_word (string): word to use for negative sign, if whole is empty
-- use_one (boolean): false: 2+1/2 → "two and a half"; true: "two and one-half"
local function fraction_to_english(whole, numerator, denominator, sp_us, negative_word, use_one)
if numerator or denominator then
local finished = (whole == nil or whole == '')
local sign = ''
if numerator then
if finished and numerator:sub(1, 1) == '-' then
numerator = numerator:sub(2)
sign = negative_word .. ' '
end
else
numerator = '1'
end
if not numerator:match('^%d+$') or not denominator or not denominator:match('^%d+$') then
return 'unsupported', ''
end
numerator = tonumber(numerator)
denominator = tonumber(denominator)
local dendata = denominators[denominator]
if not (dendata and 1 <= numerator and numerator <= 99) then
return 'unsupported', ''
end
local numstr, denstr
local sep = '-'
if numerator == 1 then
denstr = sp_us and dendata.us or dendata[1]
if finished or use_one then
numstr = 'one'
elseif denstr:match('^[aeiou]') then
numstr = 'an'
sep = ' '
else
numstr = 'a'
sep = ' '
end
else
numstr = numeral_to_english_less_100(numerator)
denstr = dendata.plural
if not denstr then
denstr = (sp_us and dendata.us or dendata[1]) .. 's'
end
end
if finished then
return 'finished', sign .. numstr .. sep .. denstr
end
return 'ok', ' and ' .. numstr .. sep .. denstr
end
return 'ok', ''
end
-- Takes a decimal number and converts it to English text.
-- Return nil if a fraction cannot be converted (only some numbers are supported for fractions).
-- num (string or nil): the number to convert.
-- Can be an arbitrarily large decimal, such as "-123456789123456789.345", and
-- can use scientific notation (e.g. "1.23E5").
-- May fail for very large numbers not listed in "groups" such as "1E4000".
-- num is nil if there is no whole number before a fraction.
-- numerator (string or nil): numerator of fraction (nil if no fraction)
-- denominator (string or nil): denominator of fraction (nil if no fraction)
-- capitalize (boolean): whether to capitalize the result (e.g. 'One' instead of 'one')
-- use_and (boolean): whether to use the word 'and' between tens/ones place and higher places
-- hyphenate (boolean): whether to hyphenate all words in the result, useful as an adjective
-- ordinal (boolean): whether to produce an ordinal (e.g. 'first' instead of 'one')
-- plural (boolean): whether to pluralize the resulting number
-- links: nil: do not add any links; 'on': link "billion" and larger to Orders of magnitude article;
-- any other text: list of numbers to link (e.g. "billion,quadrillion")
-- negative_word: word to use for negative sign (typically 'negative' or 'minus'; nil to use default)
-- round: nil or '': no rounding; 'on': round to nearest two-word number; 'up'/'down': round up/down to two-word number
-- zero: word to use for value '0' (nil to use default)
-- use_one (boolean): false: 2+1/2 → "two and a half"; true: "two and one-half"
local function _numeral_to_english(num, numerator, denominator, capitalize, use_and, hyphenate, ordinal, plural, links, negative_word, round, zero, use_one)
if not negative_word then
if use_and then
-- TODO Should 'minus' be used when do not have sp=us?
-- If so, need to update testcases, and need to fix "minus zero".
-- negative_word = 'minus'
negative_word = 'negative'
else
negative_word = 'negative'
end
end
local status, fraction_text = fraction_to_english(num, numerator, denominator, not use_and, negative_word, use_one)
if status == 'unsupported' then
return nil
end
if status == 'finished' then
-- Input is a fraction with no whole number.
-- Hack to avoid executing stuff that depends on num being a number.
local s = fraction_text
if hyphenate then s = s:gsub("%s", "-") end
if capitalize then s = s:gsub("^%l", string.upper) end
return s
end
num = scientific_notation_to_decimal(num)
if round and round ~= '' then
if round ~= 'on' and round ~= 'up' and round ~= 'down' then
error("Invalid rounding mode")
end
num = round_for_english(num, round)
end
-- Separate into negative sign, num (digits before decimal), decimal_places (digits after decimal)
local MINUS = '−' -- Unicode U+2212 MINUS SIGN (may be in values from [[Module:Convert]])
if num:sub(1, #MINUS) == MINUS then
num = '-' .. num:sub(#MINUS + 1) -- replace MINUS with '-'
elseif num:sub(1, 1) == '+' then
num = num:sub(2) -- ignore any '+'
end
local negative = num:find("^%-")
local decimal_places, subs = num:gsub("^%-?%d*%.(%d+)$", "%1")
if subs == 0 then decimal_places = nil end
num, subs = num:gsub("^%-?(%d*)%.?%d*$", "%1")
if num == '' and decimal_places then num = '0' end
if subs == 0 or num == '' then error("Invalid decimal numeral") end
-- For each group of 3 digits except the last one, print with appropriate group name (e.g. million)
local s = ''
while #num > 3 do
if s ~= '' then s = s .. ' ' end
local group_num = math.floor((#num - 1) / 3)
local group = groups[group_num]
local group_digits = #num - group_num*3
s = s .. numeral_to_english_less_1000(num:sub(1, group_digits), false, false, false, zero) .. ' '
if links and (((links == 'on' and group_num >= 3) or links:find(group)) and group_num <= 13) then
s = s .. '[[Orders_of_magnitude_(numbers)#10' .. group_num*3 .. '|' .. group .. ']]'
else
s = s .. group
end
num = num:sub(1 + group_digits)
num = num:gsub("^0*", "") -- Trim leading zeros
end
-- Handle final three digits of integer part
if s ~= '' and num ~= '' then
if #num <= 2 and use_and then
s = s .. ' and '
else
s = s .. ' '
end
end
if s == '' or num ~= '' then
s = s .. numeral_to_english_less_1000(num, use_and, ordinal, plural, zero)
elseif ordinal or plural then
-- Round numbers like "one million" take standard suffixes for ordinal/plural
s = s .. standard_suffix(ordinal, plural)
end
-- For decimal places (if any) output "point" followed by spelling out digit by digit
if decimal_places then
s = s .. ' point'
for i = 1, #decimal_places do
s = s .. ' ' .. ones_position[tonumber(decimal_places:sub(i,i))]
end
end
s = s:gsub("^%s*(.-)%s*$", "%1") -- Trim whitespace
if ordinal and plural then s = s .. 's' end -- s suffix works for all ordinals
if negative and s ~= zero then s = negative_word .. ' ' .. s end
s = s:gsub("negative zero", "zero")
s = s .. fraction_text
if hyphenate then s = s:gsub("%s", "-") end
if capitalize then s = s:gsub("^%l", string.upper) end
return s
end
local function _numeral_to_english2(args)
local num = tostring(args.num)
num = num:gsub("^%s*(.-)%s*$", "%1") -- Trim whitespace
num = num:gsub(",", "") -- Remove commas
num = num:gsub("^<span[^<>]*></span>", "") -- Generated by Template:age
if num ~= '' then -- a fraction may have an empty whole number
if not num:find("^%-?%d*%.?%d*%-?[Ee]?[+%-]?%d*$") then
-- Input not in a valid format, try to eval it as an expr to see
-- if that produces a number (e.g. "3 + 5" will become "8").
local noerr, result = pcall(mw.ext.ParserFunctions.expr, num)
if noerr then
num = result
end
end
end
-- Call helper function passing args
return _numeral_to_english(
num,
args['numerator'],
args['denominator'],
args['capitalize'],
args['use_and'],
args['hyphenate'],
args['ordinal'],
args['plural'],
args['links'],
args['negative_word'],
args['round'],
args['zero'],
args['use_one']
) or ''
end
local p = { -- Functions that can be called from another module
roman_to_numeral = roman_to_numeral,
spell_number = _numeral_to_english,
spell_number2 = _numeral_to_english2,
english_to_ordinal = english_to_ordinal,
english_to_numeral = english_to_numeral,
}
function p._roman_to_numeral(frame) -- Callable via {{#invoke:ConvertNumeric|_roman_to_numeral|VI}}
return roman_to_numeral(frame.args[1])
end
function p._english_to_ordinal(frame) -- callable via {{#invoke:ConvertNumeric|_english_to_ordinal|First}}
return english_to_ordinal(frame.args[1])
end
function p._english_to_numeral(frame) -- callable via {{#invoke:ConvertNumeric|_english_to_numeral|One}}
return english_to_numeral(frame.args[1])
end
function p.numeral_to_english(frame)
local args = frame.args
-- Tail call to helper function passing args from frame
return _numeral_to_english2{
['num'] = args[1],
['numerator'] = args['numerator'],
['denominator'] = args['denominator'],
['capitalize'] = args['case'] == 'U' or args['case'] == 'u',
['use_and'] = args['sp'] ~= 'us',
['hyphenate'] = args['adj'] == 'on',
['ordinal'] = args['ord'] == 'on',
['plural'] = args['pl'] == 'on',
['links'] = args['lk'],
['negative_word'] = args['negative'],
['round'] = args['round'],
['zero'] = args['zero'],
['use_one'] = args['one'] == 'one' -- experiment: using '|one=one' makes fraction 2+1/2 give "two and one-half" instead of "two and a half"
}
end
---- recursive function for p.decToHex
local function decToHexDigit(dec)
local dig = {"0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"}
local div = math.floor(dec/16)
local mod = dec-(16*div)
if div >= 1 then return decToHexDigit(div)..dig[mod+1] else return dig[mod+1] end
end -- I think this is supposed to be done with a tail call but first I want something that works at all
---- finds all the decimal numbers in the input text and hexes each of them
function p.decToHex(frame)
local args=frame.args
local parent=frame.getParent(frame)
local pargs={}
if parent then pargs=parent.args end
local text=args[1] or pargs[1] or ""
local minlength=args.minlength or pargs.minlength or 1
minlength=tonumber(minlength)
local prowl=mw.ustring.gmatch(text,"(.-)(%d+)")
local output=""
repeat
local chaff,dec=prowl()
if not(dec) then break end
local hex=decToHexDigit(dec)
while (mw.ustring.len(hex)<minlength) do hex="0"..hex end
output=output..chaff..hex
until false
local chaff=mw.ustring.match(text,"(%D+)$") or ""
return output..chaff
end
return p
dbb876f8710ee1407b421a28b3e9bc5a6ea36cda
Module:Exponential search
828
327
421
2023-02-10T20:10:53Z
wikipedia>Uzume
0
strict
Scribunto
text/plain
-- This module provides a generic exponential search algorithm.
require[[strict]]
local checkType = require('libraryUtil').checkType
local floor = math.floor
local function midPoint(lower, upper)
return floor(lower + (upper - lower) / 2)
end
local function search(testFunc, i, lower, upper)
if testFunc(i) then
if i + 1 == upper then
return i
end
lower = i
if upper then
i = midPoint(lower, upper)
else
i = i * 2
end
return search(testFunc, i, lower, upper)
else
upper = i
i = midPoint(lower, upper)
return search(testFunc, i, lower, upper)
end
end
return function (testFunc, init)
checkType('Exponential search', 1, testFunc, 'function')
checkType('Exponential search', 2, init, 'number', true)
if init and (init < 1 or init ~= floor(init) or init == math.huge) then
error(string.format(
"invalid init value '%s' detected in argument #2 to " ..
"'Exponential search' (init value must be a positive integer)",
tostring(init)
), 2)
end
init = init or 2
if not testFunc(1) then
return nil
end
return search(testFunc, init, 1, nil)
end
a9037be0c44536be79b2d7a26155bfb907368ae7
Template:Val
10
717
1097
2023-04-02T01:46:23Z
wikipedia>Dinoguy1000
0
correct safesubst usage
wikitext
text/x-wiki
<includeonly>{{safesubst:<noinclude/>#invoke:val|main}}</includeonly><noinclude>
{{documentation}}
</noinclude>
de315e9728588de49567fc363ccc28b987b6e298
Template:Fraction/styles.css
10
728
1119
2023-05-15T17:30:42Z
wikipedia>Izno
0
clip-path now supported
sanitized-css
text/css
/* {{pp|small=y}} */
.frac {
white-space: nowrap;
}
.frac .num,
.frac .den {
font-size: 80%;
line-height: 0; /* we want this inline */
vertical-align: super;
}
.frac .den {
vertical-align: sub;
}
/* [[Template:Screen reader-only]] is canonical implementation onwiki */
.sr-only {
border: 0;
clip: rect(0, 0, 0, 0);
clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
/* white-space: nowrap; /* already have nowrap above */
}
b28507c69a3866957f0cad2cbdb76d24154ba271
Module:Hatnote list
828
337
441
2023-11-13T21:00:31Z
wikipedia>Nihiltres
0
Updated from sandbox: added support for punctuation collapse when text is italicized. The update's content includes changes by users Johnuniq, Dexxor, and Nihiltres.
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Hatnote list --
-- --
-- This module produces and formats lists for use in hatnotes. In particular, --
-- it implements the for-see list, i.e. lists of "For X, see Y" statements, --
-- as used in {{about}}, {{redirect}}, and their variants. Also introduced --
-- are andList & orList helpers for formatting lists with those conjunctions. --
--------------------------------------------------------------------------------
local mArguments --initialize lazily
local mFormatLink = require('Module:Format link')
local mHatnote = require('Module:Hatnote')
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
--------------------------------------------------------------------------------
-- List stringification helper functions
--
-- These functions are used for stringifying lists, usually page lists inside
-- the "Y" portion of "For X, see Y" for-see items.
--------------------------------------------------------------------------------
--default options table used across the list stringification functions
local stringifyListDefaultOptions = {
conjunction = "and",
separator = ",",
altSeparator = ";",
space = " ",
formatted = false
}
--Searches display text only
local function searchDisp(haystack, needle)
return string.find(
string.sub(haystack, (string.find(haystack, '|') or 0) + 1), needle
)
end
-- Stringifies a list generically; probably shouldn't be used directly
local function stringifyList(list, options)
-- Type-checks, defaults, and a shortcut
checkType("stringifyList", 1, list, "table")
if #list == 0 then return nil end
checkType("stringifyList", 2, options, "table", true)
options = options or {}
for k, v in pairs(stringifyListDefaultOptions) do
if options[k] == nil then options[k] = v end
end
local s = options.space
-- Format the list if requested
if options.formatted then
list = mFormatLink.formatPages(
{categorizeMissing = mHatnote.missingTargetCat}, list
)
end
-- Set the separator; if any item contains it, use the alternate separator
local separator = options.separator
for k, v in pairs(list) do
if searchDisp(v, separator) then
separator = options.altSeparator
break
end
end
-- Set the conjunction, apply Oxford comma, and force a comma if #1 has "§"
local conjunction = s .. options.conjunction .. s
if #list == 2 and searchDisp(list[1], "§") or #list > 2 then
conjunction = separator .. conjunction
end
-- Return the formatted string
return mw.text.listToText(list, separator .. s, conjunction)
end
--DRY function
function p.conjList (conj, list, fmt)
return stringifyList(list, {conjunction = conj, formatted = fmt})
end
-- Stringifies lists with "and" or "or"
function p.andList (...) return p.conjList("and", ...) end
function p.orList (...) return p.conjList("or", ...) end
--------------------------------------------------------------------------------
-- For see
--
-- Makes a "For X, see [[Y]]." list from raw parameters. Intended for the
-- {{about}} and {{redirect}} templates and their variants.
--------------------------------------------------------------------------------
--default options table used across the forSee family of functions
local forSeeDefaultOptions = {
andKeyword = 'and',
title = mw.title.getCurrentTitle().text,
otherText = 'other uses',
forSeeForm = 'For %s, see %s.',
}
--Collapses duplicate punctuation at end of string, ignoring italics and links
local function punctuationCollapse (text)
return text:match("[.?!]('?)%1(%]?)%2%.$") and text:sub(1, -2) or text
end
-- Structures arguments into a table for stringification, & options
function p.forSeeArgsToTable (args, from, options)
-- Type-checks and defaults
checkType("forSeeArgsToTable", 1, args, 'table')
checkType("forSeeArgsToTable", 2, from, 'number', true)
from = from or 1
checkType("forSeeArgsToTable", 3, options, 'table', true)
options = options or {}
for k, v in pairs(forSeeDefaultOptions) do
if options[k] == nil then options[k] = v end
end
-- maxArg's gotten manually because getArgs() and table.maxn aren't friends
local maxArg = 0
for k, v in pairs(args) do
if type(k) == 'number' and k > maxArg then maxArg = k end
end
-- Structure the data out from the parameter list:
-- * forTable is the wrapper table, with forRow rows
-- * Rows are tables of a "use" string & a "pages" table of pagename strings
-- * Blanks are left empty for defaulting elsewhere, but can terminate list
local forTable = {}
local i = from
local terminated = false
-- If there is extra text, and no arguments are given, give nil value
-- to not produce default of "For other uses, see foo (disambiguation)"
if options.extratext and i > maxArg then return nil end
-- Loop to generate rows
repeat
-- New empty row
local forRow = {}
-- On blank use, assume list's ended & break at end of this loop
forRow.use = args[i]
if not args[i] then terminated = true end
-- New empty list of pages
forRow.pages = {}
-- Insert first pages item if present
table.insert(forRow.pages, args[i + 1])
-- If the param after next is "and", do inner loop to collect params
-- until the "and"'s stop. Blanks are ignored: "1|and||and|3" → {1, 3}
while args[i + 2] == options.andKeyword do
if args[i + 3] then
table.insert(forRow.pages, args[i + 3])
end
-- Increment to next "and"
i = i + 2
end
-- Increment to next use
i = i + 2
-- Append the row
table.insert(forTable, forRow)
until terminated or i > maxArg
return forTable
end
-- Stringifies a table as formatted by forSeeArgsToTable
function p.forSeeTableToString (forSeeTable, options)
-- Type-checks and defaults
checkType("forSeeTableToString", 1, forSeeTable, "table", true)
checkType("forSeeTableToString", 2, options, "table", true)
options = options or {}
for k, v in pairs(forSeeDefaultOptions) do
if options[k] == nil then options[k] = v end
end
-- Stringify each for-see item into a list
local strList = {}
if forSeeTable then
for k, v in pairs(forSeeTable) do
local useStr = v.use or options.otherText
local pagesStr =
p.andList(v.pages, true) or
mFormatLink._formatLink{
categorizeMissing = mHatnote.missingTargetCat,
link = mHatnote.disambiguate(options.title)
}
local forSeeStr = string.format(options.forSeeForm, useStr, pagesStr)
forSeeStr = punctuationCollapse(forSeeStr)
table.insert(strList, forSeeStr)
end
end
if options.extratext then table.insert(strList, punctuationCollapse(options.extratext..'.')) end
-- Return the concatenated list
return table.concat(strList, ' ')
end
-- Produces a "For X, see [[Y]]" string from arguments. Expects index gaps
-- but not blank/whitespace values. Ignores named args and args < "from".
function p._forSee (args, from, options)
local forSeeTable = p.forSeeArgsToTable(args, from, options)
return p.forSeeTableToString(forSeeTable, options)
end
-- As _forSee, but uses the frame.
function p.forSee (frame, from, options)
mArguments = require('Module:Arguments')
return p._forSee(mArguments.getArgs(frame), from, options)
end
return p
1c8e6212115f76ecc3db8d05137011cd18207988
Template:Fraction
10
727
1117
2024-01-16T00:53:18Z
wikipedia>Jonesey95
0
readability per TPER
wikitext
text/x-wiki
<templatestyles src="Fraction/styles.css" /><!--
--><span class="frac"><!--
-->{{#if:{{{3|}}}<!-- if 3
-->|{{{1}}}<span class="sr-only">+</span><span class="num">{{{2}}}</span>⁄<span class="den">{{{3}}}</span><!-- then 1 2/3
-->|{{#if:{{{2|}}}<!-- elseif 2
-->|<span class="num">{{{1}}}</span>⁄<span class="den">{{{2}}}</span><!-- then 1/2
-->|{{#if:{{{1|}}}<!-- elseif 1
-->|<span class="num">1</span>⁄<span class="den">{{{1}}}</span><!-- then 1/1
-->|⁄<!-- else 0, a slash
-->}}<!-- endif 1
-->}}<!-- endif 2
-->}}<!-- endif 3
--></span><noinclude>
{{documentation}}
</noinclude>
92a487359898e00b80676732b41757019446ae53
Template:Hlist
10
826
1281
2024-02-17T05:01:35Z
wikipedia>Pppery
0
Changed protection settings for "[[Template:Hlist]]": Always cascade protected via main page, for consistency ([Edit=Require administrator access] (indefinite) [Move=Require administrator access] (indefinite))
wikitext
text/x-wiki
{{<includeonly>safesubst:</includeonly>#invoke:list|horizontal}}<noinclude>
{{documentation}}
<!-- Categories go on the /doc subpage, and interwikis go on Wikidata. -->
</noinclude>
9e3824c2e3c0e0dbef2f37556ac0b994987fecf9
Template:Sfrac/styles.css
10
732
1127
2024-03-18T19:02:06Z
wikipedia>Izno
0
ws, add clip-path
sanitized-css
text/css
/* {{pp|small=y}} */
.sfrac {
white-space: nowrap;
}
.sfrac.tion,
.sfrac .tion {
display: inline-block;
vertical-align: -0.5em;
font-size: 85%;
text-align: center;
}
.sfrac .num {
display: block;
line-height: 1em;
margin: 0.0em 0.1em;
border-bottom: 1px solid;
}
.sfrac .den {
display: block;
line-height: 1em;
margin: 0.1em 0.1em;
}
/* [[Template:Screen reader-only]] is canonical implementation onwiki */
.sr-only {
border: 0;
clip: rect(0, 0, 0, 0); /* removed from CSS */
clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
/* white-space: nowrap; /* already have nowrap above */
}
197429395812c1ab351775e9ab127ae0ef74564e
Module:Pagetype/config
828
333
433
2024-05-16T12:23:09Z
wikipedia>MSGJ
0
+cfg for non-existent pages
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Pagetype configuration data --
-- This page holds localisation and configuration data for Module:Pagetype. --
--------------------------------------------------------------------------------
local cfg = {} -- Don't edit this line.
--------------------------------------------------------------------------------
-- Start configuration data --
--------------------------------------------------------------------------------
-- This table holds the default page types for each namespace. Keys to this
-- table should be integers that can be used as keys to mw.site.namespaces.
cfg.pagetypes = {
[0] = 'article', -- Main namespace
[2] = 'user page',
[4] = 'project page',
[6] = 'file',
[8] = 'interface page', -- MediaWiki namespace
[10] = 'template',
[12] = 'help page',
[14] = 'category',
[100] = 'portal',
[118] = 'draft',
[710] = 'Timed Text page',
[828] = 'module',
[2300] = 'gadget',
[2302] = 'gadget definition',
[-1] = 'special page',
[-2] = 'file', -- Media namespace
}
-- This table holds the namespaces to be looked up from cfg.pagetypes by
-- default.
cfg.defaultNamespaces = {
[0] = true, -- main
[6] = true, -- file
[10] = true, -- template
[14] = true, -- category
[828] = true, -- module
}
-- This table holds the namespaces to be looked up from cfg.pagetypes if
-- cfg.defaultnsExtended is set.
cfg.extendedNamespaces = {
[0] = true, -- main
[2] = true, -- user
[4] = true, -- project
[6] = true, -- file
[8] = true, -- mediawiki
[10] = true, -- template
[12] = true, -- help
[14] = true, -- category
[100] = true, -- portal
[118] = true, -- draft
[828] = true, -- module
}
-- This table holds custom aliases for each namespace.
cfg.customNamespaceAliases = {
[0] = {'main'},
}
-- The parameter name to set which default namespace values to be looked up from
-- cfg.pagetypes.
cfg.defaultns = 'defaultns'
-- The value of cfg.defaultns to set all namespaces, including talk.
cfg.defaultnsAll = 'all'
-- The value of cfg.defaultns to set the namespaces listed in
-- cfg.extendedNamespaces
cfg.defaultnsExtended = 'extended'
-- The value of cfg.defaultns to set no default namespaces.
cfg.defaultnsNone = 'none'
-- The parameter name to use for talk pages.
cfg.talk = 'talk'
-- The default value for talk pages.
cfg.talkDefault = 'talk page'
-- The parameter name to use for disambiguation pages page.
cfg.dab = 'dab'
-- The parameter name to use for non-existent pages.
cfg.ne = 'nonexistent'
cfg.neDefault = 'page'
cfg.softRedirect = 'soft_redirect'
cfg.softRedirectDefault = 'redirect'
cfg.sia = 'sia'
cfg.siaDefault = 'article'
cfg.rfd = 'redirect'
cfg.rfdDefault = 'redirect'
-- This table holds the different possible aliases for disambiguation-class
-- pages. These should be lower-case.
cfg.dabAliases = {
['disambiguation'] = true,
['disambig'] = true,
['disamb'] = true,
['dab'] = true,
}
-- The default value for disambiguation pages.
cfg.dabDefault = 'page'
-- The parameter name to use for N/A-class page.
cfg.na = 'na'
-- This table holds the different possible aliases for N/A-class pages. These
-- should be lower-case.
cfg.naAliases = {
['na'] = true,
['n/a'] = true,
}
-- The default value for N/A-class pages.
cfg.naDefault = 'page'
-- The parameter name to use for redirects.
cfg.redirect = 'redirect'
-- The default value to use for redirects.
cfg.redirectDefault = 'redirect'
-- The parameter name for undefined namespaces.
cfg.other = 'other'
-- The value used if the module detects an undefined namespace.
cfg.otherDefault = 'page'
-- The usual suffix denoting a plural.
cfg.plural = 's'
-- This table holds plurals not formed by a simple suffix.
cfg.irregularPlurals = {
["category"] = "categories"
}
--------------------------------------------------------------------------------
-- End configuration data --
--------------------------------------------------------------------------------
return cfg -- Don't edit this line
33b76bd60283986954f6a6203f163f6b304b95ee
Module:List
828
828
1285
2024-05-19T16:45:46Z
wikipedia>Pppery
0
Per edit request
Scribunto
text/plain
local libUtil = require('libraryUtil')
local checkType = libUtil.checkType
local mTableTools = require('Module:TableTools')
local p = {}
local listTypes = {
['bulleted'] = true,
['unbulleted'] = true,
['horizontal'] = true,
['ordered'] = true,
['horizontal_ordered'] = true
}
function p.makeListData(listType, args)
-- Constructs a data table to be passed to p.renderList.
local data = {}
-- Classes and TemplateStyles
data.classes = {}
data.templatestyles = ''
if listType == 'horizontal' or listType == 'horizontal_ordered' then
table.insert(data.classes, 'hlist')
data.templatestyles = mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Hlist/styles.css' }
}
elseif listType == 'unbulleted' then
table.insert(data.classes, 'plainlist')
data.templatestyles = mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Plainlist/styles.css' }
}
end
table.insert(data.classes, args.class)
-- Main div style
data.style = args.style
-- Indent for horizontal lists
if listType == 'horizontal' or listType == 'horizontal_ordered' then
local indent = tonumber(args.indent)
indent = indent and indent * 1.6 or 0
if indent > 0 then
data.marginLeft = indent .. 'em'
end
end
-- List style types for ordered lists
-- This could be "1, 2, 3", "a, b, c", or a number of others. The list style
-- type is either set by the "type" attribute or the "list-style-type" CSS
-- property.
if listType == 'ordered' or listType == 'horizontal_ordered' then
data.listStyleType = args.list_style_type or args['list-style-type']
data.type = args['type']
-- Detect invalid type attributes and attempt to convert them to
-- list-style-type CSS properties.
if data.type
and not data.listStyleType
and not tostring(data.type):find('^%s*[1AaIi]%s*$')
then
data.listStyleType = data.type
data.type = nil
end
end
-- List tag type
if listType == 'ordered' or listType == 'horizontal_ordered' then
data.listTag = 'ol'
else
data.listTag = 'ul'
end
-- Start number for ordered lists
data.start = args.start
if listType == 'horizontal_ordered' then
-- Apply fix to get start numbers working with horizontal ordered lists.
local startNum = tonumber(data.start)
if startNum then
data.counterReset = 'listitem ' .. tostring(startNum - 1)
end
end
-- List style
-- ul_style and ol_style are included for backwards compatibility. No
-- distinction is made for ordered or unordered lists.
data.listStyle = args.list_style
-- List items
-- li_style is included for backwards compatibility. item_style was included
-- to be easier to understand for non-coders.
data.itemStyle = args.item_style or args.li_style
data.items = {}
for _, num in ipairs(mTableTools.numKeys(args)) do
local item = {}
item.content = args[num]
item.style = args['item' .. tostring(num) .. '_style']
or args['item_style' .. tostring(num)]
item.value = args['item' .. tostring(num) .. '_value']
or args['item_value' .. tostring(num)]
table.insert(data.items, item)
end
return data
end
function p.renderList(data)
-- Renders the list HTML.
-- Return the blank string if there are no list items.
if type(data.items) ~= 'table' or #data.items < 1 then
return ''
end
-- Render the main div tag.
local root = mw.html.create('div')
for _, class in ipairs(data.classes or {}) do
root:addClass(class)
end
root:css{['margin-left'] = data.marginLeft}
if data.style then
root:cssText(data.style)
end
-- Render the list tag.
local list = root:tag(data.listTag or 'ul')
list
:attr{start = data.start, type = data.type}
:css{
['counter-reset'] = data.counterReset,
['list-style-type'] = data.listStyleType
}
if data.listStyle then
list:cssText(data.listStyle)
end
-- Render the list items
for _, t in ipairs(data.items or {}) do
local item = list:tag('li')
if data.itemStyle then
item:cssText(data.itemStyle)
end
if t.style then
item:cssText(t.style)
end
item
:attr{value = t.value}
:wikitext(t.content)
end
return data.templatestyles .. tostring(root)
end
function p.renderTrackingCategories(args)
local isDeprecated = false -- Tracks deprecated parameters.
for k, v in pairs(args) do
k = tostring(k)
if k:find('^item_style%d+$') or k:find('^item_value%d+$') then
isDeprecated = true
break
end
end
local ret = ''
if isDeprecated then
ret = ret .. '[[Category:List templates with deprecated parameters]]'
end
return ret
end
function p.makeList(listType, args)
if not listType or not listTypes[listType] then
error(string.format(
"bad argument #1 to 'makeList' ('%s' is not a valid list type)",
tostring(listType)
), 2)
end
checkType('makeList', 2, args, 'table')
local data = p.makeListData(listType, args)
local list = p.renderList(data)
local trackingCategories = p.renderTrackingCategories(args)
return list .. trackingCategories
end
for listType in pairs(listTypes) do
p[listType] = function (frame)
local mArguments = require('Module:Arguments')
local origArgs = mArguments.getArgs(frame, {
frameOnly = ((frame and frame.args and frame.args.frameonly or '') ~= ''),
valueFunc = function (key, value)
if not value or not mw.ustring.find(value, '%S') then return nil end
if mw.ustring.find(value, '^%s*[%*#;:]') then
return value
else
return value:match('^%s*(.-)%s*$')
end
return nil
end
})
-- Copy all the arguments to a new table, for faster indexing.
local args = {}
for k, v in pairs(origArgs) do
args[k] = v
end
return p.makeList(listType, args)
end
end
return p
44af96bdee7ebfa2ecf19acd4461d7a35c75856a
Module:Pagetype
828
332
431
2024-05-21T17:35:20Z
wikipedia>MSGJ
0
fix for files and interface messages which do exist but are not stored locally
Scribunto
text/plain
--------------------------------------------------------------------------------
-- --
-- This meta-module which automatically detects namespaces, and allows --
-- for a great deal of customisation. It can easily be ported to other --
-- wikis by changing the values in the [[Module:Pagetype/config]]. --
-- --
--------------------------------------------------------------------------------
-- Load config.
local cfg = mw.loadData('Module:Pagetype/config')
-- Load required modules.
local yesno = require('Module:Yesno')
local p = {}
-- Look up a namespace argument in the args table.
local function lookUpNamespaceArg(args, key)
local arg = args[key]
-- Convert "yes", "1" etc. to true, "no", "0" etc. to false, and leave
-- other values the same.
return yesno(arg, arg)
end
-- Append multiple values to an array
local function appendMultiple(target, source)
for _, value in ipairs(source) do
table.insert(target, value)
end
end
-- Get argument keys for a title's namespace
local function getNamespaceArgKeys(title)
local nsInfo = mw.site.namespaces[title.namespace]
local customAliases = cfg.customNamespaceAliases[title.namespace] or {}
local keys = {}
if nsInfo.name ~= '' then
table.insert(keys, nsInfo.name)
end
if nsInfo.canonicalName ~= nsInfo.name and nsInfo.canonicalName ~= '' then
table.insert(keys, nsInfo.canonicalName)
end
appendMultiple(keys, nsInfo.aliases)
appendMultiple(keys, customAliases)
return keys
end
-- Get the argument for a title's namespace, if it was specified in the args table.
local function getNamespaceArg(title, args)
if title.isTalkPage then
return lookUpNamespaceArg(args, cfg.talk)
end
for _, key in ipairs(getNamespaceArgKeys(title)) do
local arg = lookUpNamespaceArg(args, mw.ustring.lower(key))
if arg ~= nil then
return arg
end
end
return nil
end
-- Look up a page type specific to the title's namespace
local function getExplicitPageType(title)
if title.isTalkPage then
return cfg.talkDefault
else
return cfg.pagetypes[title.namespace]
end
end
-- Get a default page type that is not specific to the title's namespace
local function getDefaultPageType(args)
local other = lookUpNamespaceArg(args, cfg.other)
if type(other) == 'string' then
return other
else
return cfg.otherDefault
end
end
local function detectRedirects(title, args)
local redirect = lookUpNamespaceArg(args, cfg.redirect)
if redirect == false then
-- Don't detect redirects if they have been specifically disallowed.
return nil
end
-- Allow custom values for redirects.
if not title.isRedirect then
return nil
elseif type(redirect) == 'string' then
return redirect
else
return cfg.redirectDefault
end
end
local function capitalize(pageType)
local first = mw.ustring.sub(pageType, 1, 1)
local rest = mw.ustring.sub(pageType, 2)
return mw.ustring.upper(first) .. rest
end
local function pluralize(pageType)
if cfg.irregularPlurals[pageType] then
return cfg.irregularPlurals[pageType]
else
return pageType .. cfg.plural -- often 's'
end
end
local function parseContent(title, args, optionsList)
if title.namespace==828 and title.subpageText~='doc' -- don't detect modules
or not title.exists -- can't check unless page exists
then
return nil
end
local content = title:getContent()
if content == nil then
return nil
end
local templates -- lazily evaluated
for _, options in next, optionsList do
local list, parameter, default, articleOnly = unpack(options, 1, 4)
if not articleOnly or title.namespace==0 then -- only check for templates if we should...
local out = lookUpNamespaceArg(args, parameter)
if type(out) == "string" or (out ~= false and default) then -- ...and if we actually have anything to say about them
if not templates then
templates = {} -- do our delayed evaluation now that we are required to
content = require('Module:Wikitext Parsing').PrepareText(content) -- disregard templates which do not have any affect
for template in string.gmatch(content, "{{%s*([^|}]-)%s*[|}]") do
templates[#templates+1] = capitalize(template)
end
end
local wantedTemplates = mw.loadData('Module:Pagetype/' .. list)
local templateFound = false
for _, template in next, templates do
if wantedTemplates[template] then
templateFound = true
break
end
end
if templateFound then
if type(out)=='string' then
return out
elseif out ~= false and default then
return default
end
end
end
end
end
end
-- Find pages which do not exist
local function nonExistent(title, args)
local arg = lookUpNamespaceArg(args, cfg.ne)
if arg == false then
return nil
end
local exists = false
if title.exists then -- not an article if it does not exist
exists = true
elseif title.namespace==8 and mw.message.new(title.text):exists() then
exists = true
elseif title.namespace==6 and title.fileExists then
exists = true
end
if not exists then
if type(arg) == 'string' then
return arg
else
return cfg.naDefault
end
end
end
-- Get page types for mainspaces pages with an explicit class specified
local function getMainNamespaceClassPageType(title, args)
local class = args[1]
if type(class) == 'string' then -- Put in lower case so e.g. "na" and "NA" will both match
class = mw.ustring.lower(class)
end
local arg = lookUpNamespaceArg(args, cfg.na)
if arg == false then -- don't check for this class if it is specifically disallowed
return nil
end
if cfg.naAliases[class] then
if type(arg) == 'string' then
return arg
else
return cfg.naDefault
end
else
return nil
end
end
-- Get page type specified by an explicit namespace argument.
local function getNamespaceArgPageType(title, args)
local namespaceArg = getNamespaceArg(title, args)
if namespaceArg == true then
-- Namespace has been explicitly enabled, so return the default for
-- this namespace
return getExplicitPageType(title)
elseif namespaceArg == false then
-- Namespace has been explicitly disabled
return getDefaultPageType(args)
elseif namespaceArg then
-- This namespaces uses custom text
return namespaceArg
else
return nil
end
end
-- Get page type not specified or detected by other means
local function getOtherPageType(title, args)
-- Whether the title is in the set of default active namespaces which are looked up in cfg.pagetypes.
local isInDefaultActiveNamespace = false
local defaultNamespacesKey = args[cfg.defaultns]
if defaultNamespacesKey == cfg.defaultnsAll then
isInDefaultActiveNamespace = true
else
local defaultNamespaces
if defaultNamespacesKey == cfg.defaultnsExtended then
defaultNamespaces = cfg.extendedNamespaces
elseif defaultNamespacesKey == cfg.defaultnsNone then
defaultNamespaces = {}
else
defaultNamespaces = cfg.defaultNamespaces
end
isInDefaultActiveNamespace = defaultNamespaces[title.namespace]
end
if isInDefaultActiveNamespace then
return getExplicitPageType(title)
else
return getDefaultPageType(args)
end
end
function p._main(args)
local title
if args.page then
title = mw.title.new(args.page)
else
title = mw.title.getCurrentTitle()
end
if title and not yesno(args.talk, true) and args[cfg.defaultns] ~= cfg.defaultnsAll then
title = title.subjectPageTitle
end
local pageType = detectRedirects(title, args)
or nonExistent(title, args)
or parseContent(title, args, {
{'softredirect', cfg.softRedirect, cfg.softRedirectDefault},
{'setindex', cfg.sia, cfg.siaDefault, true},
{'disambiguation', cfg.dab, cfg.dabDefault, true},
{'rfd', cfg.rfd, cfg.rfdDefault},
})
or (title.namespace == 0 and getMainNamespaceClassPageType(title, args))
or getNamespaceArgPageType(title, args)
or getOtherPageType(title, args)
if yesno(args.plural, false) then
pageType = pluralize(pageType)
end
if yesno(args.caps, false) then
pageType = capitalize(pageType)
end
return pageType
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame)
return p._main(args)
end
return p
cb47b460d74d5df739ee7e300eeae512798bc475
Module:TableTools
828
328
423
2024-08-18T04:19:07Z
wikipedia>Pppery
0
Update from sandbox per request
Scribunto
text/plain
------------------------------------------------------------------------------------
-- TableTools --
-- --
-- This module includes a number of functions for dealing with Lua tables. --
-- It is a meta-module, meant to be called from other Lua modules, and should not --
-- be called directly from #invoke. --
------------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local p = {}
-- Define often-used variables and functions.
local floor = math.floor
local infinity = math.huge
local checkType = libraryUtil.checkType
local checkTypeMulti = libraryUtil.checkTypeMulti
------------------------------------------------------------------------------------
-- isPositiveInteger
--
-- This function returns true if the given value is a positive integer, and false
-- if not. Although it doesn't operate on tables, it is included here as it is
-- useful for determining whether a given table key is in the array part or the
-- hash part of a table.
------------------------------------------------------------------------------------
function p.isPositiveInteger(v)
return type(v) == 'number' and v >= 1 and floor(v) == v and v < infinity
end
------------------------------------------------------------------------------------
-- isNan
--
-- This function returns true if the given number is a NaN value, and false if
-- not. Although it doesn't operate on tables, it is included here as it is useful
-- for determining whether a value can be a valid table key. Lua will generate an
-- error if a NaN is used as a table key.
------------------------------------------------------------------------------------
function p.isNan(v)
return type(v) == 'number' and v ~= v
end
------------------------------------------------------------------------------------
-- shallowClone
--
-- This returns a clone of a table. The value returned is a new table, but all
-- subtables and functions are shared. Metamethods are respected, but the returned
-- table will have no metatable of its own.
------------------------------------------------------------------------------------
function p.shallowClone(t)
checkType('shallowClone', 1, t, 'table')
local ret = {}
for k, v in pairs(t) do
ret[k] = v
end
return ret
end
------------------------------------------------------------------------------------
-- removeDuplicates
--
-- This removes duplicate values from an array. Non-positive-integer keys are
-- ignored. The earliest value is kept, and all subsequent duplicate values are
-- removed, but otherwise the array order is unchanged.
------------------------------------------------------------------------------------
function p.removeDuplicates(arr)
checkType('removeDuplicates', 1, arr, 'table')
local isNan = p.isNan
local ret, exists = {}, {}
for _, v in ipairs(arr) do
if isNan(v) then
-- NaNs can't be table keys, and they are also unique, so we don't need to check existence.
ret[#ret + 1] = v
elseif not exists[v] then
ret[#ret + 1] = v
exists[v] = true
end
end
return ret
end
------------------------------------------------------------------------------------
-- numKeys
--
-- This takes a table and returns an array containing the numbers of any numerical
-- keys that have non-nil values, sorted in numerical order.
------------------------------------------------------------------------------------
function p.numKeys(t)
checkType('numKeys', 1, t, 'table')
local isPositiveInteger = p.isPositiveInteger
local nums = {}
for k in pairs(t) do
if isPositiveInteger(k) then
nums[#nums + 1] = k
end
end
table.sort(nums)
return nums
end
------------------------------------------------------------------------------------
-- affixNums
--
-- This takes a table and returns an array containing the numbers of keys with the
-- specified prefix and suffix. For example, for the table
-- {a1 = 'foo', a3 = 'bar', a6 = 'baz'} and the prefix "a", affixNums will return
-- {1, 3, 6}.
------------------------------------------------------------------------------------
function p.affixNums(t, prefix, suffix)
checkType('affixNums', 1, t, 'table')
checkType('affixNums', 2, prefix, 'string', true)
checkType('affixNums', 3, suffix, 'string', true)
local function cleanPattern(s)
-- Cleans a pattern so that the magic characters ()%.[]*+-?^$ are interpreted literally.
return s:gsub('([%(%)%%%.%[%]%*%+%-%?%^%$])', '%%%1')
end
prefix = prefix or ''
suffix = suffix or ''
prefix = cleanPattern(prefix)
suffix = cleanPattern(suffix)
local pattern = '^' .. prefix .. '([1-9]%d*)' .. suffix .. '$'
local nums = {}
for k in pairs(t) do
if type(k) == 'string' then
local num = mw.ustring.match(k, pattern)
if num then
nums[#nums + 1] = tonumber(num)
end
end
end
table.sort(nums)
return nums
end
------------------------------------------------------------------------------------
-- numData
--
-- Given a table with keys like {"foo1", "bar1", "foo2", "baz2"}, returns a table
-- of subtables in the format
-- {[1] = {foo = 'text', bar = 'text'}, [2] = {foo = 'text', baz = 'text'}}.
-- Keys that don't end with an integer are stored in a subtable named "other". The
-- compress option compresses the table so that it can be iterated over with
-- ipairs.
------------------------------------------------------------------------------------
function p.numData(t, compress)
checkType('numData', 1, t, 'table')
checkType('numData', 2, compress, 'boolean', true)
local ret = {}
for k, v in pairs(t) do
local prefix, num = mw.ustring.match(tostring(k), '^([^0-9]*)([1-9][0-9]*)$')
if num then
num = tonumber(num)
local subtable = ret[num] or {}
if prefix == '' then
-- Positional parameters match the blank string; put them at the start of the subtable instead.
prefix = 1
end
subtable[prefix] = v
ret[num] = subtable
else
local subtable = ret.other or {}
subtable[k] = v
ret.other = subtable
end
end
if compress then
local other = ret.other
ret = p.compressSparseArray(ret)
ret.other = other
end
return ret
end
------------------------------------------------------------------------------------
-- compressSparseArray
--
-- This takes an array with one or more nil values, and removes the nil values
-- while preserving the order, so that the array can be safely traversed with
-- ipairs.
------------------------------------------------------------------------------------
function p.compressSparseArray(t)
checkType('compressSparseArray', 1, t, 'table')
local ret = {}
local nums = p.numKeys(t)
for _, num in ipairs(nums) do
ret[#ret + 1] = t[num]
end
return ret
end
------------------------------------------------------------------------------------
-- sparseIpairs
--
-- This is an iterator for sparse arrays. It can be used like ipairs, but can
-- handle nil values.
------------------------------------------------------------------------------------
function p.sparseIpairs(t)
checkType('sparseIpairs', 1, t, 'table')
local nums = p.numKeys(t)
local i = 0
local lim = #nums
return function ()
i = i + 1
if i <= lim then
local key = nums[i]
return key, t[key]
else
return nil, nil
end
end
end
------------------------------------------------------------------------------------
-- size
--
-- This returns the size of a key/value pair table. It will also work on arrays,
-- but for arrays it is more efficient to use the # operator.
------------------------------------------------------------------------------------
function p.size(t)
checkType('size', 1, t, 'table')
local i = 0
for _ in pairs(t) do
i = i + 1
end
return i
end
local function defaultKeySort(item1, item2)
-- "number" < "string", so numbers will be sorted before strings.
local type1, type2 = type(item1), type(item2)
if type1 ~= type2 then
return type1 < type2
elseif type1 == 'table' or type1 == 'boolean' or type1 == 'function' then
return tostring(item1) < tostring(item2)
else
return item1 < item2
end
end
------------------------------------------------------------------------------------
-- keysToList
--
-- Returns an array of the keys in a table, sorted using either a default
-- comparison function or a custom keySort function.
------------------------------------------------------------------------------------
function p.keysToList(t, keySort, checked)
if not checked then
checkType('keysToList', 1, t, 'table')
checkTypeMulti('keysToList', 2, keySort, {'function', 'boolean', 'nil'})
end
local arr = {}
local index = 1
for k in pairs(t) do
arr[index] = k
index = index + 1
end
if keySort ~= false then
keySort = type(keySort) == 'function' and keySort or defaultKeySort
table.sort(arr, keySort)
end
return arr
end
------------------------------------------------------------------------------------
-- sortedPairs
--
-- Iterates through a table, with the keys sorted using the keysToList function.
-- If there are only numerical keys, sparseIpairs is probably more efficient.
------------------------------------------------------------------------------------
function p.sortedPairs(t, keySort)
checkType('sortedPairs', 1, t, 'table')
checkType('sortedPairs', 2, keySort, 'function', true)
local arr = p.keysToList(t, keySort, true)
local i = 0
return function ()
i = i + 1
local key = arr[i]
if key ~= nil then
return key, t[key]
else
return nil, nil
end
end
end
------------------------------------------------------------------------------------
-- isArray
--
-- Returns true if the given value is a table and all keys are consecutive
-- integers starting at 1.
------------------------------------------------------------------------------------
function p.isArray(v)
if type(v) ~= 'table' then
return false
end
local i = 0
for _ in pairs(v) do
i = i + 1
if v[i] == nil then
return false
end
end
return true
end
------------------------------------------------------------------------------------
-- isArrayLike
--
-- Returns true if the given value is iterable and all keys are consecutive
-- integers starting at 1.
------------------------------------------------------------------------------------
function p.isArrayLike(v)
if not pcall(pairs, v) then
return false
end
local i = 0
for _ in pairs(v) do
i = i + 1
if v[i] == nil then
return false
end
end
return true
end
------------------------------------------------------------------------------------
-- invert
--
-- Transposes the keys and values in an array. For example, {"a", "b", "c"} ->
-- {a = 1, b = 2, c = 3}. Duplicates are not supported (result values refer to
-- the index of the last duplicate) and NaN values are ignored.
------------------------------------------------------------------------------------
function p.invert(arr)
checkType("invert", 1, arr, "table")
local isNan = p.isNan
local map = {}
for i, v in ipairs(arr) do
if not isNan(v) then
map[v] = i
end
end
return map
end
------------------------------------------------------------------------------------
-- listToSet
--
-- Creates a set from the array part of the table. Indexing the set by any of the
-- values of the array returns true. For example, {"a", "b", "c"} ->
-- {a = true, b = true, c = true}. NaN values are ignored as Lua considers them
-- never equal to any value (including other NaNs or even themselves).
------------------------------------------------------------------------------------
function p.listToSet(arr)
checkType("listToSet", 1, arr, "table")
local isNan = p.isNan
local set = {}
for _, v in ipairs(arr) do
if not isNan(v) then
set[v] = true
end
end
return set
end
------------------------------------------------------------------------------------
-- deepCopy
--
-- Recursive deep copy function. Preserves identities of subtables.
------------------------------------------------------------------------------------
local function _deepCopy(orig, includeMetatable, already_seen)
if type(orig) ~= "table" then
return orig
end
-- already_seen stores copies of tables indexed by the original table.
local copy = already_seen[orig]
if copy ~= nil then
return copy
end
copy = {}
already_seen[orig] = copy -- memoize before any recursion, to avoid infinite loops
for orig_key, orig_value in pairs(orig) do
copy[_deepCopy(orig_key, includeMetatable, already_seen)] = _deepCopy(orig_value, includeMetatable, already_seen)
end
if includeMetatable then
local mt = getmetatable(orig)
if mt ~= nil then
setmetatable(copy, _deepCopy(mt, true, already_seen))
end
end
return copy
end
function p.deepCopy(orig, noMetatable, already_seen)
checkType("deepCopy", 3, already_seen, "table", true)
return _deepCopy(orig, not noMetatable, already_seen or {})
end
------------------------------------------------------------------------------------
-- sparseConcat
--
-- Concatenates all values in the table that are indexed by a number, in order.
-- sparseConcat{a, nil, c, d} => "acd"
-- sparseConcat{nil, b, c, d} => "bcd"
------------------------------------------------------------------------------------
function p.sparseConcat(t, sep, i, j)
local arr = {}
local arr_i = 0
for _, v in p.sparseIpairs(t) do
arr_i = arr_i + 1
arr[arr_i] = v
end
return table.concat(arr, sep, i, j)
end
------------------------------------------------------------------------------------
-- length
--
-- Finds the length of an array, or of a quasi-array with keys such as "data1",
-- "data2", etc., using an exponential search algorithm. It is similar to the
-- operator #, but may return a different value when there are gaps in the array
-- portion of the table. Intended to be used on data loaded with mw.loadData. For
-- other tables, use #.
-- Note: #frame.args in frame object always be set to 0, regardless of the number
-- of unnamed template parameters, so use this function for frame.args.
------------------------------------------------------------------------------------
function p.length(t, prefix)
-- requiring module inline so that [[Module:Exponential search]] which is
-- only needed by this one function doesn't get millions of transclusions
local expSearch = require("Module:Exponential search")
checkType('length', 1, t, 'table')
checkType('length', 2, prefix, 'string', true)
return expSearch(function (i)
local key
if prefix then
key = prefix .. tostring(i)
else
key = i
end
return t[key] ~= nil
end) or 0
end
------------------------------------------------------------------------------------
-- inArray
--
-- Returns true if searchElement is a member of the array, and false otherwise.
-- Equivalent to JavaScript array.includes(searchElement) or
-- array.includes(searchElement, fromIndex), except fromIndex is 1 indexed
------------------------------------------------------------------------------------
function p.inArray(array, searchElement, fromIndex)
checkType("inArray", 1, array, "table")
-- if searchElement is nil, error?
fromIndex = tonumber(fromIndex)
if fromIndex then
if (fromIndex < 0) then
fromIndex = #array + fromIndex + 1
end
if fromIndex < 1 then fromIndex = 1 end
for _, v in ipairs({unpack(array, fromIndex)}) do
if v == searchElement then
return true
end
end
else
for _, v in pairs(array) do
if v == searchElement then
return true
end
end
end
return false
end
------------------------------------------------------------------------------------
-- merge
--
-- Given the arrays, returns an array containing the elements of each input array
-- in sequence.
------------------------------------------------------------------------------------
function p.merge(...)
local arrays = {...}
local ret = {}
for i, arr in ipairs(arrays) do
checkType('merge', i, arr, 'table')
for _, v in ipairs(arr) do
ret[#ret + 1] = v
end
end
return ret
end
------------------------------------------------------------------------------------
-- extend
--
-- Extends the first array in place by appending all elements from the second
-- array.
------------------------------------------------------------------------------------
function p.extend(arr1, arr2)
checkType('extend', 1, arr1, 'table')
checkType('extend', 2, arr2, 'table')
for _, v in ipairs(arr2) do
arr1[#arr1 + 1] = v
end
end
return p
27b6a4e23d902c05ad6e005059248318bffc2a4e
Module:Template invocation
828
731
1125
2024-09-05T20:21:20Z
wikipedia>Pppery
0
Update name call to fix a few edge cases per request
Scribunto
text/plain
-- This module provides functions for making MediaWiki template invocations.
local checkType = require('libraryUtil').checkType
local p = {}
------------------------------------------------------------------------
-- Name: p.name
-- Purpose: Find a template invocation name from a page name or a
-- mw.title object.
-- Description: This function detects whether a string or a mw.title
-- object has been passed in, and uses that to find a
-- template name as it is used in template invocations.
-- Parameters: title - full page name or mw.title object for the
-- template (string or mw.title object)
-- Returns: String
------------------------------------------------------------------------
function p.name(title)
if type(title) == 'string' then
title = mw.title.new(title)
if not title or #title.prefixedText == 0 or #title.interwiki > 0 then
error("invalid title in parameter #1 of function 'name'", 2)
end
elseif type(title) ~= 'table' or type(title.getContent) ~= 'function' then
error("parameter #1 of function 'name' must be a string or a mw.title object", 2)
end
if title.namespace == 10 then
local text = title.text
local check = mw.title.new(text, 10)
-- Exclude the prefix, unless we have something like "Template:Category:Foo", which can't be abbreviated to "Category:Foo".
return check and mw.title.equals(title, check) and text or title.prefixedText
elseif title.namespace == 0 then
return ':' .. title.prefixedText
else
return title.prefixedText
end
end
------------------------------------------------------------------------
-- Name: p.invocation
-- Purpose: Construct a MediaWiki template invocation.
-- Description: This function makes a template invocation from the
-- name and the arguments given. Note that it isn't
-- perfect: we have no way of knowing what whitespace was
-- in the original invocation, the named parameters will be
-- alphabetically sorted, and any parameters with duplicate keys
-- will be removed.
-- Parameters: name - the template name, formatted as it will appear
-- in the invocation. (string)
-- args - a table of template arguments. (table)
-- format - formatting options. (string, optional)
-- Set to "nowiki" to escape, curly braces, pipes and
-- equals signs with their HTML entities. The default
-- is unescaped.
-- Returns: String
------------------------------------------------------------------------
function p.invocation(name, args, format)
checkType('invocation', 1, name, 'string')
checkType('invocation', 2, args, 'table')
checkType('invocation', 3, format, 'string', true)
-- Validate the args table and make a copy to work from. We need to
-- make a copy of the table rather than just using the original, as
-- some of the values may be erased when building the invocation.
local invArgs = {}
for k, v in pairs(args) do
local typek = type(k)
local typev = type(v)
if typek ~= 'string' and typek ~= 'number'
or typev ~= 'string' and typev ~= 'number'
then
error("invalid arguments table in parameter #2 of " ..
"'invocation' (keys and values must be strings or numbers)", 2)
end
invArgs[k] = v
end
-- Get the separators to use.
local seps = {
openb = '{{',
closeb = '}}',
pipe = '|',
equals = '='
}
if format == 'nowiki' then
for k, v in pairs(seps) do
seps[k] = mw.text.nowiki(v)
end
end
-- Build the invocation body with numbered args first, then named.
local ret = {}
ret[#ret + 1] = seps.openb
ret[#ret + 1] = name
for k, v in ipairs(invArgs) do
if type(v) == 'string' and v:find('=', 1, true) then
-- Likely something like 1=foo=bar which needs to be displayed as a named arg.
else
ret[#ret + 1] = seps.pipe
ret[#ret + 1] = v
invArgs[k] = nil -- Erase the key so that we don't add the value twice
end
end
local keys = {} -- sort parameter list; better than arbitrary order
for k, _ in pairs(invArgs) do
keys[#keys + 1] = k
end
table.sort(keys,
function (a, b)
-- Sort with keys of type number first, then string.
if type(a) == type(b) then
return a < b
elseif type(a) == 'number' then
return true
end
end
)
local maybeSpace = '' -- First named parameter should not be separated by a space
for _, v in ipairs(keys) do -- Add named args based on sorted parameter list
ret[#ret + 1] = maybeSpace .. seps.pipe
ret[#ret + 1] = tostring(v)
ret[#ret + 1] = seps.equals
ret[#ret + 1] = invArgs[v]
maybeSpace = ' '
end
ret[#ret + 1] = seps.closeb
return table.concat(ret)
end
return p
1670c64056477574789c5c21349ec2234f60dd9c
Module:Convert/data
828
721
1105
2024-10-26T23:10:16Z
wikipedia>Johnuniq
0
update from sandbox per [[Template talk:Convert#Module version 30]]
Scribunto
text/plain
-- Conversion data used by [[Module:Convert]] which uses mw.loadData() for
-- read-only access to this module so that it is loaded only once per page.
-- See [[:en:Template:Convert/Transwiki guide]] if copying to another wiki.
--
-- These data tables follow:
-- all_units all properties for a unit, including default output
-- default_exceptions exceptions for default output ('kg' and 'g' have different defaults)
-- link_exceptions exceptions for links ('kg' and 'g' have different links)
--
-- These tables are generated by a script which reads the wikitext of a page that
-- documents the required properties of each unit; see [[:en:Module:Convert/doc]].
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local all_units = {
["Gy"] = {
_name1 = "gray",
_symbol = "Gy",
utype = "absorbed radiation dose",
scale = 1,
prefixes = 1,
default = "rad",
link = "Gray (unit)",
},
["rad"] = {
_name1 = "rad",
_symbol = "rad",
utype = "absorbed radiation dose",
scale = 0.01,
prefixes = 1,
default = "Gy",
link = "Rad (unit)",
},
["cm/s2"] = {
name1 = "centimetre per second squared",
name1_us = "centimeter per second squared",
name2 = "centimetres per second squared",
name2_us = "centimeters per second squared",
symbol = "cm/s<sup>2</sup>",
utype = "acceleration",
scale = 0.01,
default = "ft/s2",
link = "Gal (unit)",
},
["ft/s2"] = {
name1 = "foot per second squared",
name2 = "feet per second squared",
symbol = "ft/s<sup>2</sup>",
utype = "acceleration",
scale = 0.3048,
default = "m/s2",
},
["g0"] = {
name1 = "standard gravity",
name2 = "standard gravities",
symbol = "''g''<sub>0</sub>",
utype = "acceleration",
scale = 9.80665,
default = "m/s2",
},
["g-force"] = {
name2 = "''g''",
symbol = "''g''",
utype = "acceleration",
scale = 9.80665,
default = "m/s2",
link = "g-force",
},
["km/hs"] = {
name1 = "kilometre per hour per second",
name1_us = "kilometer per hour per second",
name2 = "kilometres per hour per second",
name2_us = "kilometers per hour per second",
symbol = "km/(h⋅s)",
utype = "acceleration",
scale = 0.27777777777777779,
default = "mph/s",
link = "Acceleration",
},
["km/s2"] = {
name1 = "kilometre per second squared",
name1_us = "kilometer per second squared",
name2 = "kilometres per second squared",
name2_us = "kilometers per second squared",
symbol = "km/s<sup>2</sup>",
utype = "acceleration",
scale = 1000,
default = "mph/s",
link = "Acceleration",
},
["m/s2"] = {
name1 = "metre per second squared",
name1_us = "meter per second squared",
name2 = "metres per second squared",
name2_us = "meters per second squared",
symbol = "m/s<sup>2</sup>",
utype = "acceleration",
scale = 1,
default = "ft/s2",
},
["mph/s"] = {
name1 = "mile per hour per second",
name2 = "miles per hour per second",
symbol = "mph/s",
utype = "acceleration",
scale = 0.44704,
default = "km/hs",
link = "Acceleration",
},
["km/h/s"] = {
target = "km/hs",
},
["standard gravity"] = {
target = "g0",
},
["1000sqft"] = {
name1 = "thousand square feet",
name2 = "thousand square feet",
symbol = "1000 sq ft",
utype = "area",
scale = 92.90304,
default = "m2",
link = "Square foot",
},
["a"] = {
_name1 = "are",
_symbol = "a",
utype = "area",
scale = 100,
prefixes = 1,
default = "sqft",
link = "Hectare#Are",
},
["acre"] = {
symbol = "acre",
usename = 1,
utype = "area",
scale = 4046.8564224,
default = "ha",
subdivs = { ["rood"] = { 4, default = "ha" }, ["sqperch"] = { 160, default = "ha" } },
},
["acre-sing"] = {
target = "acre",
},
["arpent"] = {
symbol = "arpent",
usename = 1,
utype = "area",
scale = 3418.89,
default = "ha",
},
["cda"] = {
name1 = "cuerda",
symbol = "cda",
utype = "area",
scale = 3930.395625,
default = "ha acre",
},
["daa"] = {
name1 = "decare",
symbol = "daa",
utype = "area",
scale = 1000,
default = "km2 sqmi",
},
["dunam"] = {
symbol = "dunam",
usename = 1,
utype = "area",
scale = 1000,
default = "km2 sqmi",
},
["dunum"] = {
symbol = "dunum",
usename = 1,
utype = "area",
scale = 1000,
default = "km2 sqmi",
link = "Dunam",
},
["ha"] = {
name1 = "hectare",
symbol = "ha",
utype = "area",
scale = 10000,
default = "acre",
},
["hectare"] = {
name1 = "hectare",
symbol = "ha",
usename = 1,
utype = "area",
scale = 10000,
default = "acre",
},
["Irish acre"] = {
name1 = "Irish acre",
symbol = "Irish acres",
utype = "area",
scale = 6555.2385024,
default = "ha",
link = "Acre (Irish)",
},
["m2"] = {
_name1 = "square metre",
_name1_us= "square meter",
_symbol = "m<sup>2</sup>",
prefix_position= 8,
utype = "area",
scale = 1,
prefixes = 2,
default = "sqft",
link = "Square metre",
},
["pondemaat"] = {
name1 = "pondemaat",
name2 = "pondemaat",
symbol = "pond",
utype = "area",
scale = 3674.363358816,
default = "m2",
link = ":nl:pondemaat",
},
["pyeong"] = {
name2 = "pyeong",
symbol = "pyeong",
usename = 1,
utype = "area",
scale = 3.3057851239669422,
default = "m2",
},
["rai"] = {
name2 = "rai",
symbol = "rai",
utype = "area",
scale = 1600,
default = "m2",
link = "Rai (unit)",
},
["rood"] = {
symbol = "rood",
usename = 1,
utype = "area",
scale = 1011.7141056,
default = "sqft m2",
subdivs = { ["sqperch"] = { 40, default = "m2" } },
link = "Rood (unit)",
},
["sqfoot"] = {
name1 = "square foot",
name2 = "square foot",
symbol = "sq ft",
utype = "area",
scale = 0.09290304,
default = "m2",
},
["sqft"] = {
name1 = "square foot",
name2 = "square feet",
symbol = "sq ft",
utype = "area",
scale = 0.09290304,
default = "m2",
},
["sqin"] = {
name1 = "square inch",
name2 = "square inches",
symbol = "sq in",
utype = "area",
scale = 0.00064516,
default = "cm2",
},
["sqmi"] = {
name1 = "square mile",
symbol = "sq mi",
utype = "area",
scale = 2589988.110336,
default = "km2",
},
["sqnmi"] = {
name1 = "square nautical mile",
symbol = "sq nmi",
utype = "area",
scale = 3429904,
default = "km2 sqmi",
link = "Nautical mile",
},
["sqperch"] = {
name2 = "perches",
symbol = "perch",
usename = 1,
utype = "area",
scale = 25.29285264,
default = "m2",
link = "Rod (unit)#Area and volume",
},
["sqverst"] = {
symbol = "square verst",
usename = 1,
utype = "area",
scale = 1138062.24,
default = "km2 sqmi",
link = "Verst",
},
["sqyd"] = {
name1 = "square yard",
symbol = "sq yd",
utype = "area",
scale = 0.83612736,
default = "m2",
},
["tsubo"] = {
name2 = "tsubo",
symbol = "tsubo",
usename = 1,
utype = "area",
scale = 3.3057851239669422,
default = "m2",
link = "Japanese units of measurement#Area",
},
["acres"] = {
target = "acre",
},
["are"] = {
target = "a",
},
["decare"] = {
target = "daa",
},
["foot2"] = {
target = "sqfoot",
},
["ft2"] = {
target = "sqft",
},
["in2"] = {
target = "sqin",
symbol = "in<sup>2</sup>",
},
["km²"] = {
target = "km2",
},
["mi2"] = {
target = "sqmi",
},
["million acre"] = {
target = "e6acre",
},
["million acres"] = {
target = "e6acre",
},
["million hectares"] = {
target = "e6ha",
},
["m²"] = {
target = "m2",
},
["nmi2"] = {
target = "sqnmi",
},
["pond"] = {
target = "pondemaat",
},
["sq arp"] = {
target = "arpent",
},
["sqkm"] = {
target = "km2",
},
["sqm"] = {
target = "m2",
},
["square verst"] = {
target = "sqverst",
},
["verst2"] = {
target = "sqverst",
},
["yd2"] = {
target = "sqyd",
},
["m2/ha"] = {
name1 = "square metre per hectare",
name1_us = "square meter per hectare",
name2 = "square metres per hectare",
name2_us = "square meters per hectare",
symbol = "m<sup>2</sup>/ha",
utype = "area per unit area",
scale = 0.0001,
default = "sqft/acre",
link = "Basal area",
},
["sqft/acre"] = {
name1 = "square foot per acre",
name2 = "square feet per acre",
symbol = "sq ft/acre",
utype = "area per unit area",
scale = 2.295684113865932e-5,
default = "m2/ha",
link = "Basal area",
},
["cent"] = {
name1 = "cent",
symbol = "¢",
utype = "cent",
scale = 1,
default = "cent",
link = "Cent (currency)",
},
["¢"] = {
target = "cent",
},
["A.h"] = {
name1 = "ampere hour",
symbol = "A⋅h",
utype = "charge",
scale = 3600,
default = "coulomb",
},
["coulomb"] = {
_name1 = "coulomb",
_symbol = "C",
utype = "charge",
scale = 1,
prefixes = 1,
default = "e",
link = "Coulomb",
},
["e"] = {
name1 = "elementary charge",
symbol = "''e''",
utype = "charge",
scale = 1.602176487e-19,
default = "coulomb",
},
["g-mol"] = {
name1 = "gram-mole",
symbol = "g‑mol",
utype = "chemical amount",
scale = 1,
default = "lbmol",
link = "Mole (unit)",
},
["gmol"] = {
name1 = "gram-mole",
symbol = "gmol",
utype = "chemical amount",
scale = 1,
default = "lbmol",
link = "Mole (unit)",
},
["kmol"] = {
name1 = "kilomole",
symbol = "kmol",
utype = "chemical amount",
scale = 1000,
default = "lbmol",
link = "Mole (unit)",
},
["lb-mol"] = {
name1 = "pound-mole",
symbol = "lb‑mol",
utype = "chemical amount",
scale = 453.59237,
default = "mol",
},
["lbmol"] = {
name1 = "pound-mole",
symbol = "lbmol",
utype = "chemical amount",
scale = 453.59237,
default = "mol",
},
["mol"] = {
name1 = "mole",
symbol = "mol",
utype = "chemical amount",
scale = 1,
default = "lbmol",
link = "Mole (unit)",
},
["kgCO2/L"] = {
name1 = "kilogram per litre",
name1_us = "kilogram per liter",
name2 = "kilograms per litre",
name2_us = "kilograms per liter",
symbol = "kg(CO<sub>2</sub>)/L",
utype = "co2 per unit volume",
scale = 1000,
default = "lbCO2/USgal",
link = "Exhaust gas",
},
["lbCO2/USgal"] = {
name1 = "pound per US gallon",
name2 = "pounds per US gallon",
symbol = "lbCO2/US gal",
utype = "co2 per unit volume",
scale = 119.82642731689663,
default = "kgCO2/L",
link = "Exhaust gas",
},
["oz/lb"] = {
per = { "oz", "lb" },
utype = "concentration",
default = "mg/kg",
},
["mg/kg"] = {
per = { "mg", "kg" },
utype = "concentration",
default = "oz/lb",
},
["g/dm3"] = {
name1 = "gram per cubic decimetre",
name1_us = "gram per cubic decimeter",
name2 = "grams per cubic decimetre",
name2_us = "grams per cubic decimeter",
symbol = "g/dm<sup>3</sup>",
utype = "density",
scale = 1,
default = "kg/m3",
link = "Density",
},
["g/L"] = {
name1 = "gram per litre",
name1_us = "gram per liter",
name2 = "grams per litre",
name2_us = "grams per liter",
symbol = "g/L",
utype = "density",
scale = 1,
default = "lb/cuin",
link = "Density",
},
["g/mL"] = {
name1 = "gram per millilitre",
name1_us = "gram per milliliter",
name2 = "grams per millilitre",
name2_us = "grams per milliliter",
symbol = "g/mL",
utype = "density",
scale = 1000,
default = "lb/cuin",
link = "Density",
},
["g/ml"] = {
name1 = "gram per millilitre",
name1_us = "gram per milliliter",
name2 = "grams per millilitre",
name2_us = "grams per milliliter",
symbol = "g/ml",
utype = "density",
scale = 1000,
default = "lb/cuin",
link = "Density",
},
["kg/dm3"] = {
name1 = "kilogram per cubic decimetre",
name1_us = "kilogram per cubic decimeter",
name2 = "kilograms per cubic decimetre",
name2_us = "kilograms per cubic decimeter",
symbol = "kg/dm<sup>3</sup>",
utype = "density",
scale = 1000,
default = "lb/cuft",
link = "Density",
},
["kg/L"] = {
name1 = "kilogram per litre",
name1_us = "kilogram per liter",
name2 = "kilograms per litre",
name2_us = "kilograms per liter",
symbol = "kg/L",
utype = "density",
scale = 1000,
default = "lb/USgal",
link = "Density",
},
["kg/l"] = {
name1 = "kilogram per litre",
name1_us = "kilogram per liter",
name2 = "kilograms per litre",
name2_us = "kilograms per liter",
symbol = "kg/l",
utype = "density",
scale = 1000,
default = "lb/USgal",
link = "Density",
},
["kg/m3"] = {
name1 = "kilogram per cubic metre",
name1_us = "kilogram per cubic meter",
name2 = "kilograms per cubic metre",
name2_us = "kilograms per cubic meter",
symbol = "kg/m<sup>3</sup>",
utype = "density",
scale = 1,
default = "lb/cuyd",
link = "Density",
},
["lb/cuft"] = {
name1 = "pound per cubic foot",
name2 = "pounds per cubic foot",
symbol = "lb/cu ft",
utype = "density",
scale = 16.018463373960142,
default = "g/cm3",
link = "Density",
},
["lb/cuin"] = {
name1 = "pound per cubic inch",
name2 = "pounds per cubic inch",
symbol = "lb/cu in",
utype = "density",
scale = 27679.904710203122,
default = "g/cm3",
link = "Density",
},
["lb/cuyd"] = {
name1 = "pound per cubic yard",
name2 = "pounds per cubic yard",
symbol = "lb/cu yd",
utype = "density",
scale = 0.5932764212577829,
default = "kg/m3",
link = "Density",
},
["lb/impgal"] = {
name1 = "pound per imperial gallon",
name2 = "pounds per imperial gallon",
symbol = "lb/imp gal",
utype = "density",
scale = 99.776372663101697,
default = "kg/L",
link = "Density",
},
["lb/in3"] = {
name1 = "pound per cubic inch",
name2 = "pounds per cubic inch",
symbol = "lb/cu in",
utype = "density",
scale = 27679.904710203122,
default = "g/cm3",
link = "Density",
},
["lb/U.S.gal"] = {
name1 = "pound per U.S. gallon",
name2 = "pounds per U.S. gallon",
symbol = "lb/U.S. gal",
utype = "density",
scale = 119.82642731689663,
default = "kg/L",
link = "Density",
},
["lb/USbu"] = {
name1 = "pound per US bushel",
name2 = "pounds per US bushel",
symbol = "lb/US bu",
utype = "density",
scale = 12.871859780974471,
default = "kg/m3",
link = "Bushel",
},
["lb/USgal"] = {
name1 = "pound per US gallon",
name2 = "pounds per US gallon",
symbol = "lb/US gal",
utype = "density",
scale = 119.82642731689663,
default = "kg/L",
link = "Density",
},
["lbm/cuin"] = {
name1 = "pound mass per cubic inch",
name2 = "pounds mass per cubic inch",
symbol = "lbm/cu in",
utype = "density",
scale = 27679.904710203122,
default = "g/cm3",
link = "Density",
},
["mg/L"] = {
name1 = "milligram per litre",
name1_us = "milligram per liter",
name2 = "milligrams per litre",
name2_us = "milligrams per liter",
symbol = "mg/L",
utype = "density",
scale = 0.001,
default = "lb/cuin",
link = "Density",
},
["oz/cuin"] = {
name1 = "ounce per cubic inch",
name2 = "ounces per cubic inch",
symbol = "oz/cu in",
utype = "density",
scale = 1729.9940443876951,
default = "g/cm3",
link = "Density",
},
["g/cm3"] = {
per = { "g", "cm3" },
utype = "density",
default = "lb/cuin",
},
["g/m3"] = {
per = { "g", "m3" },
utype = "density",
default = "lb/cuyd",
link = "Density",
},
["Mg/m3"] = {
per = { "Mg", "m3" },
utype = "density",
default = "lb/cuft",
},
["mg/l"] = {
per = { "mg", "ll" },
utype = "density",
default = "oz/cuin",
},
["μg/dL"] = {
per = { "μg", "dL" },
utype = "density",
default = "lb/cuin",
},
["μg/l"] = {
per = { "μg", "ll" },
utype = "density",
default = "oz/cuin",
},
["lb/ft3"] = {
target = "lb/cuft",
},
["lb/yd3"] = {
target = "lb/cuyd",
},
["lbm/in3"] = {
target = "lbm/cuin",
},
["mcg/dL"] = {
target = "μg/dL",
},
["oz/in3"] = {
target = "oz/cuin",
},
["ug/dL"] = {
target = "μg/dL",
},
["ug/l"] = {
target = "μg/l",
},
["B.O.T.U."] = {
name1 = "Board of Trade Unit",
symbol = "B.O.T.U.",
utype = "energy",
scale = 3600000,
default = "MJ",
link = "Kilowatt-hour",
},
["bboe"] = {
name1 = "barrel of oil equivalent",
name2 = "barrels of oil equivalent",
symbol = "bboe",
utype = "energy",
scale = 6117863200,
default = "GJ",
},
["BOE"] = {
name1 = "barrel of oil equivalent",
name2 = "barrels of oil equivalent",
symbol = "BOE",
utype = "energy",
scale = 6117863200,
default = "GJ",
},
["BTU"] = {
name1 = "British thermal unit",
symbol = "BTU",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
},
["Btu"] = {
name1 = "British thermal unit",
symbol = "Btu",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
},
["BTU-39F"] = {
name1 = "British thermal unit (39°F)",
name2 = "British thermal units (39°F)",
symbol = "BTU<sub>39°F</sub>",
utype = "energy",
scale = 1059.67,
default = "kJ",
link = "British thermal unit",
},
["Btu-39F"] = {
name1 = "British thermal unit (39°F)",
name2 = "British thermal units (39°F)",
symbol = "Btu<sub>39°F</sub>",
utype = "energy",
scale = 1059.67,
default = "kJ",
link = "British thermal unit",
},
["BTU-59F"] = {
name1 = "British thermal unit (59°F)",
name2 = "British thermal units (59°F)",
symbol = "BTU<sub>59°F</sub>",
utype = "energy",
scale = 1054.804,
default = "kJ",
link = "British thermal unit",
},
["Btu-59F"] = {
name1 = "British thermal unit (59°F)",
name2 = "British thermal units (59°F)",
symbol = "Btu<sub>59°F</sub>",
utype = "energy",
scale = 1054.804,
default = "kJ",
link = "British thermal unit",
},
["BTU-60F"] = {
name1 = "British thermal unit (60°F)",
name2 = "British thermal units (60°F)",
symbol = "BTU<sub>60°F</sub>",
utype = "energy",
scale = 1054.68,
default = "kJ",
link = "British thermal unit",
},
["Btu-60F"] = {
name1 = "British thermal unit (60°F)",
name2 = "British thermal units (60°F)",
symbol = "Btu<sub>60°F</sub>",
utype = "energy",
scale = 1054.68,
default = "kJ",
link = "British thermal unit",
},
["BTU-63F"] = {
name1 = "British thermal unit (63°F)",
name2 = "British thermal units (63°F)",
symbol = "BTU<sub>63°F</sub>",
utype = "energy",
scale = 1054.6,
default = "kJ",
link = "British thermal unit",
},
["Btu-63F"] = {
name1 = "British thermal unit (63°F)",
name2 = "British thermal units (63°F)",
symbol = "Btu<sub>63°F</sub>",
utype = "energy",
scale = 1054.6,
default = "kJ",
link = "British thermal unit",
},
["BTU-ISO"] = {
name1 = "British thermal unit (ISO)",
name2 = "British thermal units (ISO)",
symbol = "BTU<sub>ISO</sub>",
utype = "energy",
scale = 1055.056,
default = "kJ",
link = "British thermal unit",
},
["Btu-ISO"] = {
target = "BTU-ISO",
},
["BTU-IT"] = {
name1 = "British thermal unit (IT)",
name2 = "British thermal units (IT)",
symbol = "BTU<sub>IT</sub>",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
link = "British thermal unit",
},
["Btu-IT"] = {
name1 = "British thermal unit (IT)",
name2 = "British thermal units (IT)",
symbol = "Btu<sub>IT</sub>",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
link = "British thermal unit",
},
["BTU-mean"] = {
name1 = "British thermal unit (mean)",
name2 = "British thermal units (mean)",
symbol = "BTU<sub>mean</sub>",
utype = "energy",
scale = 1055.87,
default = "kJ",
link = "British thermal unit",
},
["Btu-mean"] = {
name1 = "British thermal unit (mean)",
name2 = "British thermal units (mean)",
symbol = "Btu<sub>mean</sub>",
utype = "energy",
scale = 1055.87,
default = "kJ",
link = "British thermal unit",
},
["BTU-th"] = {
name1 = "British thermal unit (thermochemical)",
name2 = "British thermal units (thermochemical)",
symbol = "BTU<sub>th</sub>",
utype = "energy",
scale = 1054.35026444,
default = "kJ",
link = "British thermal unit",
},
["Btu-th"] = {
name1 = "British thermal unit (thermochemical)",
name2 = "British thermal units (thermochemical)",
symbol = "Btu<sub>th</sub>",
utype = "energy",
scale = 1054.35026444,
default = "kJ",
link = "British thermal unit",
},
["Cal"] = {
name1 = "calorie",
symbol = "Cal",
utype = "energy",
scale = 4184,
default = "kJ",
},
["cal"] = {
name1 = "calorie",
symbol = "cal",
utype = "energy",
scale = 4.184,
default = "J",
},
["Cal-15"] = {
name1 = "Calorie (15°C)",
name2 = "Calories (15°C)",
symbol = "Cal<sub>15</sub>",
utype = "energy",
scale = 4185.8,
default = "kJ",
link = "Calorie",
},
["cal-15"] = {
name1 = "calorie (15°C)",
name2 = "calories (15°C)",
symbol = "cal<sub>15</sub>",
utype = "energy",
scale = 4.1858,
default = "J",
link = "Calorie",
},
["Cal-IT"] = {
name1 = "Calorie (International Steam Table)",
name2 = "Calories (International Steam Table)",
symbol = "Cal<sub>IT</sub>",
utype = "energy",
scale = 4186.8,
default = "kJ",
link = "Calorie",
},
["cal-IT"] = {
name1 = "calorie (International Steam Table)",
name2 = "calories (International Steam Table)",
symbol = "cal<sub>IT</sub>",
utype = "energy",
scale = 4.1868,
default = "J",
link = "Calorie",
},
["Cal-th"] = {
name1 = "Calorie (thermochemical)",
name2 = "Calories (thermochemical)",
symbol = "Cal<sub>th</sub>",
utype = "energy",
scale = 4184,
default = "kJ",
link = "Calorie",
},
["cal-th"] = {
name1 = "calorie (thermochemical)",
name2 = "calories (thermochemical)",
symbol = "cal<sub>th</sub>",
utype = "energy",
scale = 4.184,
default = "J",
link = "Calorie",
},
["CHU-IT"] = {
name1 = "Celsius heat unit (International Table)",
name2 = "Celsius heat units (International Table)",
symbol = "CHU<sub>IT</sub>",
utype = "energy",
scale = 1899.100534716,
default = "kJ",
link = "Conversion of units#Energy",
},
["cufootnaturalgas"] = {
name1 = "cubic foot of natural gas",
name2 = "cubic foot of natural gas",
symbol = "cuftnaturalgas",
usename = 1,
utype = "energy",
scale = 1055055.85262,
default = "MJ",
link = "Conversion of units#Energy",
},
["cuftnaturalgas"] = {
name1 = "cubic foot of natural gas",
name2 = "cubic feet of natural gas",
symbol = "cuftnaturalgas",
usename = 1,
utype = "energy",
scale = 1055055.85262,
default = "MJ",
link = "Conversion of units#Energy",
},
["Eh"] = {
name1 = "Hartree",
symbol = "''E''<sub>h</sub>",
utype = "energy",
scale = 4.35974417e-18,
default = "eV",
},
["erg"] = {
symbol = "erg",
utype = "energy",
scale = 0.0000001,
default = "μJ",
},
["eV"] = {
name1 = "electronvolt",
symbol = "eV",
utype = "energy",
scale = 1.602176487e-19,
default = "aJ",
},
["feV"] = {
name1 = "femtoelectronvolt",
symbol = "feV",
utype = "energy",
scale = 1.602176487e-34,
default = "yJ",
link = "Electronvolt",
},
["foe"] = {
symbol = "foe",
utype = "energy",
scale = 1e44,
default = "YJ",
link = "Foe (unit)",
},
["ftlb"] = {
name1 = "foot-pound",
symbol = "ft⋅lb",
utype = "energy",
alttype = "torque",
scale = 1.3558179483314004,
default = "J",
link = "Foot-pound (energy)",
},
["ftlb-f"] = {
name1 = "foot-pound force",
name2 = "foot-pounds force",
symbol = "ft⋅lb<sub>f</sub>",
utype = "energy",
alttype = "torque",
scale = 1.3558179483314004,
default = "J",
link = "Foot-pound (energy)",
},
["ftlbf"] = {
name1 = "foot-pound force",
name2 = "foot-pounds force",
symbol = "ft⋅lbf",
utype = "energy",
alttype = "torque",
scale = 1.3558179483314004,
default = "J",
link = "Foot-pound (energy)",
},
["ftpdl"] = {
name1 = "foot-poundal",
symbol = "ft⋅pdl",
utype = "energy",
scale = 0.0421401100938048,
default = "J",
},
["GeV"] = {
name1 = "gigaelectronvolt",
symbol = "GeV",
utype = "energy",
scale = 1.602176487e-10,
default = "nJ",
link = "Electronvolt",
},
["gTNT"] = {
name2 = "grams of TNT",
symbol = "gram of TNT",
usename = 1,
utype = "energy",
scale = 4184,
default = "kJ",
link = "TNT equivalent",
},
["Gtoe"] = {
name1 = "gigatonne of oil equivalent",
name2 = "gigatonnes of oil equivalent",
symbol = "Gtoe",
utype = "energy",
scale = 4.1868e19,
default = "EJ",
link = "Tonne of oil equivalent",
},
["GtonTNT"] = {
name2 = "gigatons of TNT",
symbol = "gigaton of TNT",
usename = 1,
utype = "energy",
scale = 4.184e18,
default = "EJ",
link = "TNT equivalent",
},
["GtTNT"] = {
name2 = "gigatonnes of TNT",
symbol = "gigatonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e18,
default = "EJ",
link = "TNT equivalent",
},
["GW.h"] = {
name1 = "gigawatt-hour",
symbol = "GW⋅h",
utype = "energy",
scale = 3.6e12,
default = "TJ",
link = "Kilowatt-hour",
},
["GWh"] = {
name1 = "gigawatt-hour",
symbol = "GWh",
utype = "energy",
scale = 3.6e12,
default = "TJ",
link = "Kilowatt-hour",
},
["hph"] = {
name1 = "horsepower-hour",
symbol = "hp⋅h",
utype = "energy",
scale = 2684519.537696172792,
default = "kWh",
link = "Horsepower",
},
["inlb"] = {
name1 = "inch-pound",
symbol = "in⋅lb",
utype = "energy",
alttype = "torque",
scale = 0.1129848290276167,
default = "mJ",
link = "Foot-pound (energy)",
},
["inlb-f"] = {
name1 = "inch-pound force",
name2 = "inch-pounds force",
symbol = "in⋅lb<sub>f</sub>",
utype = "energy",
alttype = "torque",
scale = 0.1129848290276167,
default = "mJ",
link = "Foot-pound (energy)",
},
["inlbf"] = {
name1 = "inch-pound force",
name2 = "inch-pounds force",
symbol = "in⋅lbf",
utype = "energy",
alttype = "torque",
scale = 0.1129848290276167,
default = "mJ",
link = "Foot-pound (energy)",
},
["inoz-f"] = {
name1 = "inch-ounce force",
name2 = "inch-ounces force",
symbol = "in⋅oz<sub>f</sub>",
utype = "energy",
alttype = "torque",
scale = 0.00706155181422604375,
default = "mJ",
link = "Foot-pound (energy)",
},
["inozf"] = {
name1 = "inch-ounce force",
name2 = "inch-ounces force",
symbol = "in⋅ozf",
utype = "energy",
alttype = "torque",
scale = 0.00706155181422604375,
default = "mJ",
link = "Foot-pound (energy)",
},
["J"] = {
_name1 = "joule",
_symbol = "J",
utype = "energy",
scale = 1,
prefixes = 1,
default = "cal",
link = "Joule",
},
["kBOE"] = {
name1 = "kilo barrel of oil equivalent",
name2 = "kilo barrels of oil equivalent",
symbol = "kBOE",
utype = "energy",
scale = 6.1178632e12,
default = "TJ",
link = "Barrel of oil equivalent",
},
["kcal"] = {
name1 = "kilocalorie",
symbol = "kcal",
utype = "energy",
scale = 4184,
default = "kJ",
link = "Calorie",
},
["kcal-15"] = {
name1 = "kilocalorie (15°C)",
name2 = "kilocalories (15°C)",
symbol = "kcal<sub>15</sub>",
utype = "energy",
scale = 4185.8,
default = "kJ",
link = "Calorie",
},
["kcal-IT"] = {
name1 = "kilocalorie (International Steam Table)",
name2 = "kilocalories (International Steam Table)",
symbol = "kcal<sub>IT</sub>",
utype = "energy",
scale = 4186.8,
default = "kJ",
link = "Calorie",
},
["kcal-th"] = {
name1 = "kilocalorie (thermochemical)",
name2 = "kilocalories (thermochemical)",
symbol = "kcal<sub>th</sub>",
utype = "energy",
scale = 4184,
default = "kJ",
link = "Calorie",
},
["kerg"] = {
name1 = "kiloerg",
symbol = "kerg",
utype = "energy",
scale = 0.0001,
default = "mJ",
link = "Erg",
},
["keV"] = {
name1 = "kiloelectronvolt",
symbol = "keV",
utype = "energy",
scale = 1.602176487e-16,
default = "fJ",
link = "Electronvolt",
},
["kgTNT"] = {
name2 = "kilograms of TNT",
symbol = "kilogram of TNT",
usename = 1,
utype = "energy",
scale = 4184000,
default = "MJ",
link = "TNT equivalent",
},
["kt(TNT)"] = {
name1 = "kilotonne",
name1_us = "kiloton",
symbol = "kt",
utype = "energy",
scale = 4.184e12,
default = "TJ",
link = "TNT equivalent",
},
["ktoe"] = {
name1 = "kilotonne of oil equivalent",
name2 = "kilotonnes of oil equivalent",
symbol = "ktoe",
utype = "energy",
scale = 4.1868e13,
default = "TJ",
link = "Tonne of oil equivalent",
},
["ktonTNT"] = {
name1 = "kiloton of TNT",
name2 = "kilotons of TNT",
symbol = "kt",
utype = "energy",
scale = 4.184e12,
default = "TJ",
link = "TNT equivalent",
},
["ktTNT"] = {
name2 = "kilotonnes of TNT",
symbol = "kilotonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e12,
default = "TJ",
link = "TNT equivalent",
},
["kW.h"] = {
name1 = "kilowatt-hour",
symbol = "kW⋅h",
utype = "energy",
scale = 3600000,
default = "MJ",
},
["kWh"] = {
name1 = "kilowatt-hour",
symbol = "kWh",
utype = "energy",
scale = 3600000,
default = "MJ",
},
["Mcal"] = {
name1 = "megacalorie",
symbol = "Mcal",
utype = "energy",
scale = 4184000,
default = "MJ",
link = "Calorie",
},
["mcal"] = {
name1 = "millicalorie",
symbol = "mcal",
utype = "energy",
scale = 0.004184,
default = "mJ",
link = "Calorie",
},
["Mcal-15"] = {
name1 = "megacalorie (15°C)",
name2 = "megacalories (15°C)",
symbol = "Mcal<sub>15</sub>",
utype = "energy",
scale = 4185800,
default = "MJ",
link = "Calorie",
},
["mcal-15"] = {
name1 = "millicalorie (15°C)",
name2 = "millicalories (15°C)",
symbol = "mcal<sub>15</sub>",
utype = "energy",
scale = 0.0041858,
default = "mJ",
link = "Calorie",
},
["Mcal-IT"] = {
name1 = "megacalorie (International Steam Table)",
name2 = "megacalories (International Steam Table)",
symbol = "Mcal<sub>IT</sub>",
utype = "energy",
scale = 4186800,
default = "MJ",
link = "Calorie",
},
["mcal-IT"] = {
name1 = "millicalorie (International Steam Table)",
name2 = "millicalories (International Steam Table)",
symbol = "mcal<sub>IT</sub>",
utype = "energy",
scale = 0.0041868,
default = "mJ",
link = "Calorie",
},
["Mcal-th"] = {
name1 = "megacalorie (thermochemical)",
name2 = "megacalories (thermochemical)",
symbol = "Mcal<sub>th</sub>",
utype = "energy",
scale = 4184000,
default = "MJ",
link = "Calorie",
},
["mcal-th"] = {
name1 = "millicalorie (thermochemical)",
name2 = "millicalories (thermochemical)",
symbol = "mcal<sub>th</sub>",
utype = "energy",
scale = 0.004184,
default = "mJ",
link = "Calorie",
},
["Merg"] = {
name1 = "megaerg",
symbol = "Merg",
utype = "energy",
scale = 0.1,
default = "J",
link = "Erg",
},
["merg"] = {
name1 = "millierg",
symbol = "merg",
utype = "energy",
scale = 0.0000000001,
default = "μJ",
link = "Erg",
},
["MeV"] = {
name1 = "megaelectronvolt",
symbol = "MeV",
utype = "energy",
scale = 1.602176487e-13,
default = "pJ",
link = "Electronvolt",
},
["meV"] = {
name1 = "millielectronvolt",
symbol = "meV",
utype = "energy",
scale = 1.602176487e-22,
default = "zJ",
link = "Electronvolt",
},
["MMBtu"] = {
name1 = "million British thermal units",
name2 = "million British thermal units",
symbol = "MMBtu",
utype = "energy",
scale = 1055055852.62,
default = "GJ",
link = "British thermal unit",
},
["Mt(TNT)"] = {
name1 = "megatonne",
name1_us = "megaton",
symbol = "Mt",
utype = "energy",
scale = 4.184e15,
default = "PJ",
link = "TNT equivalent",
},
["Mtoe"] = {
name1 = "megatonne of oil equivalent",
name2 = "megatonnes of oil equivalent",
symbol = "Mtoe",
utype = "energy",
scale = 4.1868e16,
default = "PJ",
link = "Tonne of oil equivalent",
},
["MtonTNT"] = {
name1 = "megaton of TNT",
name2 = "megatons of TNT",
symbol = "Mt",
utype = "energy",
scale = 4.184e15,
default = "PJ",
link = "TNT equivalent",
},
["mtonTNT"] = {
name2 = "millitons of TNT",
symbol = "milliton of TNT",
usename = 1,
utype = "energy",
scale = 4184000,
default = "MJ",
link = "TNT equivalent",
},
["MtTNT"] = {
name2 = "megatonnes of TNT",
symbol = "megatonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e15,
default = "PJ",
link = "TNT equivalent",
},
["mtTNT"] = {
name2 = "millitonnes of TNT",
symbol = "millitonne of TNT",
usename = 1,
utype = "energy",
scale = 4184000,
default = "MJ",
link = "TNT equivalent",
},
["MW.h"] = {
name1 = "megawatt-hour",
symbol = "MW⋅h",
utype = "energy",
scale = 3600000000,
default = "GJ",
link = "Kilowatt-hour",
},
["mW.h"] = {
name1 = "milliwatt-hour",
symbol = "mW⋅h",
utype = "energy",
scale = 3.6,
default = "J",
link = "Kilowatt-hour",
},
["MWh"] = {
name1 = "megawatt-hour",
symbol = "MWh",
utype = "energy",
scale = 3600000000,
default = "GJ",
link = "Kilowatt-hour",
},
["mWh"] = {
name1 = "milliwatt-hour",
symbol = "mWh",
utype = "energy",
scale = 3.6,
default = "J",
link = "Kilowatt-hour",
},
["neV"] = {
name1 = "nanoelectronvolt",
symbol = "neV",
utype = "energy",
scale = 1.602176487e-28,
default = "yJ",
link = "Electronvolt",
},
["PeV"] = {
name1 = "petaelectronvolt",
symbol = "PeV",
utype = "energy",
scale = 0.0001602176487,
default = "mJ",
link = "Electronvolt",
},
["peV"] = {
name1 = "picoelectronvolt",
symbol = "peV",
utype = "energy",
scale = 1.602176487e-31,
default = "yJ",
link = "Electronvolt",
},
["PSh"] = {
name1 = "Pferdestärkenstunde",
symbol = "PSh",
utype = "energy",
scale = 2647795.5,
default = "kWh",
},
["quad"] = {
name1 = "quadrillion British thermal units",
name2 = "quadrillion British thermal units",
symbol = "quad",
utype = "energy",
scale = 1.054804e18,
default = "EJ",
link = "Quad (unit)",
},
["Ry"] = {
name1 = "rydberg",
symbol = "Ry",
utype = "energy",
scale = 2.1798741e-18,
default = "eV",
link = "Rydberg constant",
},
["scf"] = {
name1 = "standard cubic foot",
name2 = "standard cubic feet",
symbol = "scf",
utype = "energy",
scale = 2869.2044809344,
default = "kJ",
},
["scfoot"] = {
name1 = "standard cubic foot",
name2 = "standard cubic foot",
symbol = "scf",
utype = "energy",
scale = 2869.2044809344,
default = "kJ",
},
["t(TNT)"] = {
name1 = "tonne",
name1_us = "ton",
symbol = "t",
utype = "energy",
scale = 4184000000,
default = "GJ",
link = "TNT equivalent",
},
["TeV"] = {
name1 = "teraelectronvolt",
symbol = "TeV",
utype = "energy",
scale = 1.602176487e-7,
default = "μJ",
link = "Electronvolt",
},
["th"] = {
name1 = "thermie",
symbol = "th",
utype = "energy",
scale = 4186800,
default = "MJ",
link = "Conversion of units#Energy",
},
["thm-EC"] = {
name1 = "therm (EC)",
name2 = "therms (EC)",
symbol = "thm (EC)",
utype = "energy",
scale = 105506000,
default = "MJ",
link = "Therm",
},
["thm-UK"] = {
name1 = "therm (UK)",
name2 = "therms (UK)",
symbol = "thm (UK)",
utype = "energy",
scale = 105505585.257348,
default = "MJ",
link = "Therm",
},
["thm-US"] = {
name1 = "therm (US)",
name1_us = "therm (U.S.)",
name2 = "therms (US)",
name2_us = "therms (U.S.)",
symbol = "thm (US)",
sym_us = "thm (U.S.)",
utype = "energy",
scale = 105480400,
default = "MJ",
link = "Therm",
},
["toe"] = {
name1 = "tonne of oil equivalent",
name2 = "tonnes of oil equivalent",
symbol = "toe",
utype = "energy",
scale = 41868000000,
default = "GJ",
},
["tonTNT"] = {
name2 = "tons of TNT",
symbol = "ton of TNT",
usename = 1,
utype = "energy",
scale = 4184000000,
default = "GJ",
link = "TNT equivalent",
},
["tTNT"] = {
name2 = "tonnes of TNT",
symbol = "tonne of TNT",
usename = 1,
utype = "energy",
scale = 4184000000,
default = "GJ",
link = "TNT equivalent",
},
["TtonTNT"] = {
name2 = "teratons of TNT",
symbol = "teraton of TNT",
usename = 1,
utype = "energy",
scale = 4.184e21,
default = "ZJ",
link = "TNT equivalent",
},
["TtTNT"] = {
name2 = "teratonnes of TNT",
symbol = "teratonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e21,
default = "ZJ",
link = "TNT equivalent",
},
["TW.h"] = {
name1 = "terawatt-hour",
symbol = "TW⋅h",
utype = "energy",
scale = 3.6e15,
default = "PJ",
link = "Kilowatt-hour",
},
["TWh"] = {
name1 = "terawatt-hour",
symbol = "TWh",
utype = "energy",
scale = 3.6e15,
default = "PJ",
link = "Kilowatt-hour",
},
["W.h"] = {
name1 = "watt-hour",
symbol = "W⋅h",
utype = "energy",
scale = 3600,
default = "kJ",
link = "Kilowatt-hour",
},
["Wh"] = {
name1 = "watt-hour",
symbol = "Wh",
utype = "energy",
scale = 3600,
default = "kJ",
link = "Kilowatt-hour",
},
["μerg"] = {
name1 = "microerg",
symbol = "μerg",
utype = "energy",
scale = 1e-13,
default = "nJ",
link = "Erg",
},
["μeV"] = {
name1 = "microelectronvolt",
symbol = "μeV",
utype = "energy",
scale = 1.602176487e-25,
default = "yJ",
link = "Electronvolt",
},
["μW.h"] = {
name1 = "microwatt-hour",
symbol = "μW⋅h",
utype = "energy",
scale = 0.0036,
default = "mJ",
link = "Kilowatt-hour",
},
["μWh"] = {
name1 = "microwatt-hour",
symbol = "μWh",
utype = "energy",
scale = 0.0036,
default = "mJ",
link = "Kilowatt-hour",
},
["-kW.h"] = {
target = "kW.h",
link = "Kilowatt hour",
},
["btu"] = {
target = "BTU",
},
["Calorie"] = {
target = "Cal",
},
["ft.lbf"] = {
target = "ftlbf",
},
["ft·lbf"] = {
target = "ftlbf",
},
["g-cal-15"] = {
target = "cal-15",
},
["g-cal-IT"] = {
target = "cal-IT",
},
["g-cal-th"] = {
target = "cal-th",
},
["g-kcal-15"] = {
target = "kcal-15",
},
["g-kcal-IT"] = {
target = "kcal-IT",
},
["g-kcal-th"] = {
target = "kcal-th",
},
["g-Mcal-15"] = {
target = "Mcal-15",
},
["g-mcal-15"] = {
target = "mcal-15",
},
["g-Mcal-IT"] = {
target = "Mcal-IT",
},
["g-mcal-IT"] = {
target = "mcal-IT",
},
["g-Mcal-th"] = {
target = "Mcal-th",
},
["g-mcal-th"] = {
target = "mcal-th",
},
["GW-h"] = {
target = "GW.h",
},
["GW·h"] = {
target = "GW.h",
},
["Hartree"] = {
target = "Eh",
},
["hp.h"] = {
target = "hph",
},
["in.lb-f"] = {
target = "inlb-f",
},
["in.lbf"] = {
target = "inlbf",
},
["in.oz-f"] = {
target = "inoz-f",
},
["in.ozf"] = {
target = "inozf",
},
["kbboe"] = {
target = "kBOE",
symbol = "kbboe",
},
["kg-cal-15"] = {
target = "Cal-15",
},
["kg-cal-IT"] = {
target = "Cal-IT",
},
["kg-cal-th"] = {
target = "Cal-th",
},
["kW-h"] = {
target = "kW.h",
},
["kW·h"] = {
target = "kW.h",
},
["MW-h"] = {
target = "MW.h",
},
["mW-h"] = {
target = "mW.h",
},
["MW·h"] = {
target = "MW.h",
},
["TW-h"] = {
target = "TW.h",
},
["uerg"] = {
target = "μerg",
},
["ueV"] = {
target = "μeV",
},
["uW-h"] = {
target = "μW.h",
},
["uW.h"] = {
target = "μW.h",
},
["uWh"] = {
target = "μWh",
},
["W-h"] = {
target = "W.h",
},
["eVpar"] = {
_name1 = "electronvolt",
_symbol = "eV",
utype = "energy per chemical amount",
scale = 96485.329522144166,
prefixes = 1,
default = "kcal/mol",
link = "Electronvolt",
},
["kcal/mol"] = {
per = { "kcal", "mol" },
utype = "energy per chemical amount",
default = "kJ/mol",
link = "Kilocalorie per mole",
},
["kJ/mol"] = {
per = { "kJ", "mol" },
utype = "energy per chemical amount",
default = "kcal/mol",
link = "Joule per mole",
},
["kWh/100 km"] = {
name1 = "kilowatt-hour per 100 kilometres",
name1_us = "kilowatt-hour per 100 kilometers",
name2 = "kilowatt-hours per 100 kilometres",
name2_us = "kilowatt-hours per 100 kilometers",
symbol = "kW⋅h/100 km",
utype = "energy per unit length",
scale = 36,
default = "MJ/km kWh/mi",
link = "Kilowatt-hour",
},
["kWh/100 mi"] = {
name1 = "kilowatt-hour per 100 miles",
name2 = "kilowatt-hours per 100 miles",
symbol = "kW⋅h/100 mi",
utype = "energy per unit length",
scale = 22.3694,
default = "mpge",
link = "Miles per gallon gasoline equivalent",
},
["MJ/100 km"] = {
name1 = "megajoule per 100 kilometres",
name1_us = "megajoule per 100 kilometers",
name2 = "megajoules per 100 kilometres",
name2_us = "megajoules per 100 kilometers",
symbol = "MJ/100 km",
utype = "energy per unit length",
scale = 10,
default = "BTU/mi",
link = "British thermal unit",
},
["mpge"] = {
name1 = "mile per gallon gasoline equivalent",
name2 = "miles per gallon gasoline equivalent",
symbol = "mpg‑e",
utype = "energy per unit length",
scale = 1.3263314048360777e-5,
invert = -1,
iscomplex= true,
default = "kWh/100 mi",
link = "Miles per gallon gasoline equivalent",
},
["BTU/mi"] = {
per = { "BTU", "mi" },
utype = "energy per unit length",
default = "v > 1525 ! M ! k ! J/km",
},
["kJ/km"] = {
per = { "kJ", "km" },
utype = "energy per unit length",
default = "BTU/mi",
},
["kWh/km"] = {
per = { "-kW.h", "km" },
utype = "energy per unit length",
default = "MJ/km kWh/mi",
},
["kWh/mi"] = {
per = { "-kW.h", "mi" },
utype = "energy per unit length",
default = "kWh/km MJ/km",
},
["MJ/km"] = {
per = { "MJ", "km" },
utype = "energy per unit length",
default = "BTU/mi",
},
["mpg-e"] = {
target = "mpge",
},
["BTU/lb"] = {
name1 = "British thermal unit per pound",
name2 = "British thermal units per pound",
symbol = "BTU/lb",
utype = "energy per unit mass",
scale = 2326,
default = "kJ/kg",
link = "British thermal unit",
},
["cal/g"] = {
name1 = "calorie per gram",
name2 = "calories per gram",
symbol = "cal/g",
utype = "energy per unit mass",
scale = 4184,
default = "J/g",
},
["GJ/kg"] = {
name1 = "gigajoule per kilogram",
name2 = "gigajoules per kilogram",
symbol = "GJ/kg",
utype = "energy per unit mass",
scale = 1e9,
default = "ktTNT/t",
link = "Specific energy",
},
["J/g"] = {
name1 = "joule per gram",
name2 = "joules per gram",
symbol = "J/g",
utype = "energy per unit mass",
scale = 1000,
default = "kcal/g",
link = "Specific energy",
},
["kcal/g"] = {
name1 = "kilocalorie per gram",
name2 = "kilocalories per gram",
symbol = "kcal/g",
utype = "energy per unit mass",
scale = 4184000,
default = "kJ/g",
},
["kJ/g"] = {
name1 = "kilojoule per gram",
name2 = "kilojoules per gram",
symbol = "kJ/g",
utype = "energy per unit mass",
scale = 1000000,
default = "kcal/g",
link = "Specific energy",
},
["kJ/kg"] = {
name1 = "kilojoule per kilogram",
name2 = "kilojoules per kilogram",
symbol = "kJ/kg",
utype = "energy per unit mass",
scale = 1000,
default = "BTU/lb",
link = "Specific energy",
},
["ktonTNT/MT"] = {
name2 = "kilotons of TNT per metric ton",
symbol = "kiloton of TNT per metric ton",
usename = 1,
utype = "energy per unit mass",
scale = 4184000000,
default = "GJ/kg",
link = "TNT equivalent",
},
["ktTNT/t"] = {
name2 = "kilotonnes of TNT per tonne",
symbol = "kilotonne of TNT per tonne",
usename = 1,
utype = "energy per unit mass",
scale = 4184000000,
default = "GJ/kg",
link = "TNT equivalent",
},
["MtonTNT/MT"] = {
name2 = "megatons of TNT per metric ton",
symbol = "megaton of TNT per metric ton",
usename = 1,
utype = "energy per unit mass",
scale = 4.184e12,
default = "TJ/kg",
link = "TNT equivalent",
},
["MtTNT/MT"] = {
name2 = "megatonnes of TNT per tonne",
symbol = "megatonne of TNT per tonne",
usename = 1,
utype = "energy per unit mass",
scale = 4.184e12,
default = "TJ/kg",
link = "TNT equivalent",
},
["TJ/kg"] = {
name1 = "terajoule per kilogram",
name2 = "terajoules per kilogram",
symbol = "TJ/kg",
utype = "energy per unit mass",
scale = 1e12,
default = "MtTNT/MT",
link = "Specific energy",
},
["Cal/g"] = {
per = { "Cal", "g" },
utype = "energy per unit mass",
default = "kJ/g",
},
["BTU/cuft"] = {
per = { "BTU", "cuft" },
utype = "energy per unit volume",
default = "kJ/L",
},
["Cal/12USoz(mL)serve"] = {
per = { "Cal", "-12USoz(mL)serve" },
utype = "energy per unit volume",
default = "kJ/L",
},
["Cal/12USoz(ml)serve"] = {
per = { "Cal", "-12USoz(ml)serve" },
utype = "energy per unit volume",
default = "kJ/l",
},
["Cal/12USozserve"] = {
per = { "Cal", "-12USozserve" },
utype = "energy per unit volume",
default = "kJ/L",
},
["Cal/USoz"] = {
per = { "Cal", "USoz" },
utype = "energy per unit volume",
default = "kJ/ml",
},
["kJ/L"] = {
per = { "kJ", "L" },
utype = "energy per unit volume",
default = "BTU/cuft",
},
["kJ/l"] = {
per = { "kJ", "ll" },
utype = "energy per unit volume",
default = "BTU/cuft",
},
["kJ/ml"] = {
per = { "kJ", "ml" },
utype = "energy per unit volume",
default = "Cal/USoz",
},
["MJ/m3"] = {
per = { "MJ", "m3" },
utype = "energy per unit volume",
default = "BTU/cuft",
},
["Sv"] = {
_name1 = "sievert",
_symbol = "Sv",
utype = "equivalent radiation dose",
scale = 1,
prefixes = 1,
default = "rem",
link = "Sievert",
},
["rem"] = {
_name1 = "rem",
_symbol = "rem",
utype = "equivalent radiation dose",
scale = 0.01,
prefixes = 1,
default = "Sv",
link = "Roentgen equivalent man",
},
["g/km"] = {
name1 = "gram per kilometre",
name1_us = "gram per kilometer",
name2 = "grams per kilometre",
name2_us = "grams per kilometer",
symbol = "g/km",
utype = "exhaust emission",
scale = 1e-6,
default = "oz/mi",
link = "Exhaust gas",
},
["g/mi"] = {
name1 = "gram per mile",
name2 = "grams per mile",
symbol = "g/mi",
utype = "exhaust emission",
scale = 6.2137119223733397e-7,
default = "g/km",
link = "Exhaust gas",
},
["gCO2/km"] = {
name1 = "gram of CO<sub>2</sub> per kilometre",
name1_us = "gram of CO<sub>2</sub> per kilometer",
name2 = "grams of CO<sub>2</sub> per kilometre",
name2_us = "grams of CO<sub>2</sub> per kilometer",
symbol = "g(CO<sub>2</sub>)/km",
utype = "exhaust emission",
scale = 1e-6,
default = "ozCO2/mi",
link = "Exhaust gas",
},
["gCO2/mi"] = {
name1 = "gram of CO<sub>2</sub> per mile",
name2 = "grams of CO<sub>2</sub> per mile",
symbol = "g(CO<sub>2</sub>)/mi",
utype = "exhaust emission",
scale = 6.2137119223733397e-7,
default = "gCO2/km",
link = "Exhaust gas",
},
["kg/km"] = {
name1 = "kilogram per kilometre",
name1_us = "kilogram per kilometer",
name2 = "kilograms per kilometre",
name2_us = "kilograms per kilometer",
symbol = "kg/km",
utype = "exhaust emission",
scale = 0.001,
default = "lb/mi",
link = "Exhaust gas",
},
["kgCO2/km"] = {
name1 = "kilogram of CO<sub>2</sub> per kilometre",
name1_us = "kilogram of CO<sub>2</sub> per kilometer",
name2 = "kilograms of CO<sub>2</sub> per kilometre",
name2_us = "kilograms of CO<sub>2</sub> per kilometer",
symbol = "kg(CO<sub>2</sub>)/km",
utype = "exhaust emission",
scale = 0.001,
default = "lbCO2/mi",
link = "Exhaust gas",
},
["lb/mi"] = {
name1 = "pound per mile",
name2 = "pounds per mile",
symbol = "lb/mi",
utype = "exhaust emission",
scale = 0.00028184923173665794,
default = "kg/km",
link = "Exhaust gas",
},
["lbCO2/mi"] = {
name1 = "pound of CO<sub>2</sub> per mile",
name2 = "pounds of CO<sub>2</sub> per mile",
symbol = "lb(CO<sub>2</sub>)/mi",
utype = "exhaust emission",
scale = 0.00028184923173665794,
default = "kgCO2/km",
link = "Exhaust gas",
},
["oz/mi"] = {
name1 = "ounce per mile",
name2 = "ounces per mile",
symbol = "oz/mi",
utype = "exhaust emission",
scale = 1.7615576983541121e-5,
default = "g/km",
link = "Exhaust gas",
},
["ozCO2/mi"] = {
name1 = "ounce of CO<sub>2</sub> per mile",
name2 = "ounces of CO<sub>2</sub> per mile",
symbol = "oz(CO<sub>2</sub>)/mi",
utype = "exhaust emission",
scale = 1.7615576983541121e-5,
default = "gCO2/km",
link = "Exhaust gas",
},
["cuft/a"] = {
name1 = "cubic foot per annum",
name2 = "cubic feet per annum",
symbol = "cu ft/a",
utype = "flow",
scale = 8.9730672142368242e-10,
default = "m3/a",
link = "Cubic foot per second",
},
["cuft/d"] = {
name1 = "cubic foot per day",
name2 = "cubic feet per day",
symbol = "cu ft/d",
utype = "flow",
scale = 3.2774128000000003e-7,
default = "m3/d",
link = "Cubic foot per second",
},
["cuft/h"] = {
name1 = "cubic foot per hour",
name2 = "cubic feet per hour",
symbol = "cu ft/h",
utype = "flow",
scale = 7.8657907200000004e-6,
default = "m3/h",
link = "Cubic foot per second",
},
["cuft/min"] = {
name1 = "cubic foot per minute",
name2 = "cubic feet per minute",
symbol = "cu ft/min",
utype = "flow",
scale = 0.00047194744319999999,
default = "m3/min",
},
["cuft/s"] = {
name1 = "cubic foot per second",
name2 = "cubic feet per second",
symbol = "cu ft/s",
utype = "flow",
scale = 28316846592e-12,
default = "m3/s",
},
["cumi/a"] = {
name1 = "cubic mile per annum",
name2 = "cubic miles per annum",
symbol = "cu mi/a",
utype = "flow",
scale = 132.08171170940057,
default = "km3/a",
link = "Cubic foot per second",
},
["cuyd/h"] = {
name1 = "cubic yard per hour",
name2 = "cubic yards per hour",
symbol = "cuyd/h",
utype = "flow",
scale = 0.00021237634944000001,
default = "m3/h",
link = "Cubic foot per second",
},
["cuyd/s"] = {
name1 = "cubic yard per second",
name2 = "cubic yards per second",
symbol = "cu yd/s",
utype = "flow",
scale = 0.76455485798400002,
default = "m3/s",
},
["Goilbbl/a"] = {
name1 = "billion barrels per year",
name2 = "billion barrels per year",
symbol = "Gbbl/a",
utype = "flow",
scale = 5.0380033629933836,
default = "v * 1.58987294928 < 10 ! e6 ! e9 ! m3/a",
link = "Barrel per day",
},
["impgal/h"] = {
name1 = "imperial gallon per hour",
name2 = "imperial gallons per hour",
symbol = "imp gal/h",
utype = "flow",
scale = 1.2628027777777779e-6,
default = "m3/h",
link = "Gallon",
},
["impgal/min"] = {
name1 = "imperial gallon per minute",
name2 = "imperial gallons per minute",
symbol = "imp gal/min",
utype = "flow",
scale = 7.5768166666666671e-5,
default = "m3/s",
link = "Gallon",
},
["impgal/s"] = {
name1 = "imperial gallon per second",
name2 = "imperial gallons per second",
symbol = "impgal/s",
utype = "flow",
scale = 0.00454609,
default = "m3/s",
link = "Imperial gallons per second",
},
["km3/a"] = {
name1 = "cubic kilometre per annum",
name1_us = "cubic kilometer per annum",
name2 = "cubic kilometres per annum",
name2_us = "cubic kilometers per annum",
symbol = "km<sup>3</sup>/a",
utype = "flow",
scale = 31.68808781402895,
default = "cumi/a",
link = "Cubic metre per second",
},
["km3/d"] = {
name1 = "cubic kilometre per day",
name1_us = "cubic kilometer per day",
name2 = "cubic kilometres per day",
name2_us = "cubic kilometers per day",
symbol = "km<sup>3</sup>/d",
utype = "flow",
scale = 11574.074074074075,
default = "cuft/d",
link = "Cubic metre per second",
},
["koilbbl/a"] = {
name1 = "thousand barrels per year",
name2 = "thousand barrels per year",
symbol = "kbbl/a",
utype = "flow",
scale = 5.0380033629933841e-6,
default = "v * 1.58987294928 < 10 ! ! e3 ! m3/a",
link = "Barrel per day",
},
["koilbbl/d"] = {
name1 = "thousand barrels per day",
name2 = "thousand barrels per day",
symbol = "kbbl/d",
utype = "flow",
scale = 0.0018401307283333335,
default = "v * 1.58987294928 < 10 ! ! e3 ! m3/d",
link = "Barrel per day",
},
["L/h"] = {
name1 = "litre per hour",
name1_us = "liter per hour",
name2 = "litres per hour",
name2_us = "liters per hour",
symbol = "L/h",
utype = "flow",
scale = 2.7777777777777776e-7,
default = "impgal/h USgal/h",
link = "Cubic metre per second",
},
["L/min"] = {
name1 = "litre per minute",
name1_us = "liter per minute",
name2 = "litres per minute",
name2_us = "liters per minute",
symbol = "L/min",
utype = "flow",
scale = 1.6666666666666667e-5,
default = "impgal/min USgal/min",
link = "Cubic metre per second",
},
["L/s"] = {
name1 = "litre per second",
name1_us = "liter per second",
name2 = "litres per second",
name2_us = "liters per second",
symbol = "L/s",
utype = "flow",
scale = 0.001,
default = "cuft/s",
link = "Cubic metre per second",
},
["m3/a"] = {
name1 = "cubic metre per annum",
name1_us = "cubic meter per annum",
name2 = "cubic metres per annum",
name2_us = "cubic meters per annum",
symbol = "m<sup>3</sup>/a",
utype = "flow",
scale = 3.1688087814028947e-8,
default = "cuft/a",
link = "Cubic metre per second",
},
["m3/d"] = {
name1 = "cubic metre per day",
name1_us = "cubic meter per day",
name2 = "cubic metres per day",
name2_us = "cubic meters per day",
symbol = "m<sup>3</sup>/d",
utype = "flow",
scale = 1.1574074074074073e-5,
default = "cuft/d",
link = "Cubic metre per second",
},
["m3/h"] = {
name1 = "cubic metre per hour",
name1_us = "cubic meter per hour",
name2 = "cubic metres per hour",
name2_us = "cubic meters per hour",
symbol = "m<sup>3</sup>/h",
utype = "flow",
scale = 0.00027777777777777778,
default = "cuft/h",
link = "Cubic metre per second",
},
["m3/min"] = {
name1 = "cubic metre per minute",
name1_us = "cubic meter per minute",
name2 = "cubic metres per minute",
name2_us = "cubic meters per minute",
symbol = "m<sup>3</sup>/min",
utype = "flow",
scale = 0.016666666666666666,
default = "cuft/min",
link = "Cubic metre per second",
},
["m3/s"] = {
name1 = "cubic metre per second",
name1_us = "cubic meter per second",
name2 = "cubic metres per second",
name2_us = "cubic meters per second",
symbol = "m<sup>3</sup>/s",
utype = "flow",
scale = 1,
default = "cuft/s",
},
["Moilbbl/a"] = {
name1 = "million barrels per year",
name2 = "million barrels per year",
symbol = "Mbbl/a",
utype = "flow",
scale = 0.0050380033629933837,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3/a",
link = "Barrel per day",
},
["Moilbbl/d"] = {
name1 = "million barrels per day",
name2 = "million barrels per day",
symbol = "Mbbl/d",
utype = "flow",
scale = 1.8401307283333335,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3/d",
link = "Barrel per day",
},
["oilbbl/a"] = {
name1 = "barrel per year",
name2 = "barrels per year",
symbol = "bbl/a",
utype = "flow",
scale = 5.0380033629933841e-9,
default = "m3/a",
link = "Barrel per day",
},
["oilbbl/d"] = {
name1 = "barrel per day",
name2 = "barrels per day",
symbol = "bbl/d",
utype = "flow",
scale = 1.8401307283333336e-6,
default = "m3/d",
},
["Toilbbl/a"] = {
name1 = "trillion barrels per year",
name2 = "trillion barrels per year",
symbol = "Tbbl/a",
utype = "flow",
scale = 5038.0033629933832,
default = "v * 1.58987294928 < 10 ! e9 ! e12 ! m3/a",
link = "Barrel per day",
},
["U.S.gal/d"] = {
name1 = "U.S. gallon per day",
name2 = "U.S. gallons per day",
symbol = "U.S. gal/d",
utype = "flow",
scale = 4.3812636388888893e-8,
default = "m3/s",
customary= 1,
},
["U.S.gal/h"] = {
name1 = "gallon per hour",
name2 = "gallons per hour",
symbol = "gal/h",
utype = "flow",
scale = 1.0515032733333334e-6,
default = "m3/h",
link = "Gallon",
customary= 2,
},
["U.S.gal/min"] = {
name1 = "U.S. gallon per minute",
name2 = "U.S. gallons per minute",
symbol = "U.S. gal/min",
utype = "flow",
scale = 6.3090196400000003e-5,
default = "m3/s",
link = "Gallon",
},
["USgal/a"] = {
name1 = "US gallon per year",
name2 = "US gallons per year",
symbol = "US gal/a",
utype = "flow",
scale = 1.1995246102365199e-10,
default = "m3/s",
},
["USgal/d"] = {
name1 = "US gallon per day",
name2 = "US gallons per day",
symbol = "US gal/d",
utype = "flow",
scale = 4.3812636388888893e-8,
default = "m3/s",
},
["USgal/h"] = {
name1 = "gallon per hour",
name2 = "gallons per hour",
symbol = "gal/h",
utype = "flow",
scale = 1.0515032733333334e-6,
default = "m3/h",
link = "Gallon",
customary= 1,
},
["USgal/min"] = {
name1 = "US gallon per minute",
name2 = "US gallons per minute",
symbol = "US gal/min",
utype = "flow",
scale = 6.3090196400000003e-5,
default = "m3/s",
link = "Gallon",
},
["USgal/s"] = {
name1 = "US gallon per second",
name1_us = "U.S. gallon per second",
name2 = "US gallons per second",
name2_us = "U.S. gallons per second",
symbol = "USgal/s",
utype = "flow",
scale = 0.003785411784,
default = "m3/s",
link = "US gallons per second",
},
["ft3/a"] = {
target = "cuft/a",
},
["ft3/d"] = {
target = "cuft/d",
},
["ft3/h"] = {
target = "cuft/h",
},
["ft3/s"] = {
target = "cuft/s",
},
["Gcuft/a"] = {
target = "e9cuft/a",
},
["Gcuft/d"] = {
target = "e9cuft/d",
},
["kcuft/a"] = {
target = "e3cuft/a",
},
["kcuft/d"] = {
target = "e3cuft/d",
},
["kcuft/s"] = {
target = "e3cuft/s",
},
["Mcuft/a"] = {
target = "e6cuft/a",
},
["Mcuft/d"] = {
target = "e6cuft/d",
},
["Mcuft/s"] = {
target = "e6cuft/s",
},
["m³/s"] = {
target = "m3/s",
},
["Tcuft/a"] = {
target = "e12cuft/a",
},
["Tcuft/d"] = {
target = "e12cuft/d",
},
["u.s.gal/min"] = {
target = "U.S.gal/min",
},
["usgal/min"] = {
target = "USgal/min",
},
["-LTf"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "LTf",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["-STf"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "STf",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["dyn"] = {
name1 = "dyne",
symbol = "dyn",
utype = "force",
scale = 0.00001,
default = "gr-f",
},
["g-f"] = {
name1 = "gram-force",
name2 = "grams-force",
symbol = "g<sub>f</sub>",
utype = "force",
scale = 0.00980665,
default = "mN oz-f",
link = "Kilogram-force",
},
["gf"] = {
name1 = "gram-force",
name2 = "grams-force",
symbol = "gf",
utype = "force",
scale = 0.00980665,
default = "mN ozf",
link = "Kilogram-force",
},
["gr-f"] = {
name1 = "grain-force",
name2 = "grains-force",
symbol = "gr<sub>f</sub>",
utype = "force",
scale = 0.0006354602307515,
default = "μN",
link = "Pound (force)",
},
["grf"] = {
name1 = "grain-force",
name2 = "grains-force",
symbol = "grf",
utype = "force",
scale = 0.0006354602307515,
default = "μN",
link = "Pound (force)",
},
["kdyn"] = {
name1 = "kilodyne",
symbol = "kdyn",
utype = "force",
scale = 0.01,
default = "oz-f",
link = "Dyne",
},
["kg-f"] = {
name1 = "kilogram-force",
name2 = "kilograms-force",
symbol = "kg<sub>f</sub>",
utype = "force",
scale = 9.80665,
default = "N lb-f",
},
["kgf"] = {
name1 = "kilogram-force",
name2 = "kilograms-force",
symbol = "kgf",
utype = "force",
scale = 9.80665,
default = "N lbf",
},
["kp"] = {
name1 = "kilopond",
symbol = "kp",
utype = "force",
scale = 9.80665,
default = "N lb-f",
link = "Kilogram-force",
},
["L/T-f"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "L/T<sub>f</sub>",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["L/Tf"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "L/Tf",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["lb-f"] = {
name1 = "pound-force",
name2 = "pounds-force",
symbol = "lb<sub>f</sub>",
utype = "force",
scale = 4.4482216152605,
default = "N",
link = "Pound (force)",
},
["lbf"] = {
name1 = "pound-force",
name2 = "pounds-force",
symbol = "lbf",
utype = "force",
scale = 4.4482216152605,
default = "N",
link = "Pound (force)",
},
["lb(f)"] = {
name1 = "pound",
symbol = "lb",
utype = "force",
scale = 4.4482216152605,
default = "N",
link = "Pound (force)",
},
["LT-f"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "LT<sub>f</sub>",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["LTf"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "LTf",
usename = 1,
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["Mdyn"] = {
name1 = "megadyne",
symbol = "Mdyn",
utype = "force",
scale = 10,
default = "lb-f",
link = "Dyne",
},
["mdyn"] = {
name1 = "millidyne",
symbol = "mdyn",
utype = "force",
scale = 0.00000001,
default = "gr-f",
link = "Dyne",
},
["mg-f"] = {
name1 = "milligram-force",
name2 = "milligrams-force",
symbol = "mg<sub>f</sub>",
utype = "force",
scale = 0.00000980665,
default = "μN gr-f",
link = "Kilogram-force",
},
["mgf"] = {
name1 = "milligram-force",
name2 = "milligrams-force",
symbol = "mgf",
utype = "force",
scale = 0.00000980665,
default = "μN grf",
link = "Kilogram-force",
},
["Mp"] = {
name1 = "megapond",
symbol = "Mp",
utype = "force",
scale = 9806.65,
default = "kN LT-f ST-f",
link = "Kilogram-force",
},
["mp"] = {
name1 = "millipond",
symbol = "mp",
utype = "force",
scale = 0.00000980665,
default = "μN gr-f",
link = "Kilogram-force",
},
["N"] = {
_name1 = "newton",
_symbol = "N",
utype = "force",
scale = 1,
prefixes = 1,
default = "lb-f",
link = "Newton (unit)",
},
["oz-f"] = {
name1 = "ounce-force",
name2 = "ounces-force",
symbol = "oz<sub>f</sub>",
utype = "force",
scale = 0.2780138203095378125,
default = "mN",
link = "Pound (force)",
},
["ozf"] = {
name1 = "ounce-force",
name2 = "ounces-force",
symbol = "ozf",
utype = "force",
scale = 0.2780138203095378125,
default = "mN",
link = "Pound (force)",
},
["p"] = {
name1 = "pond",
symbol = "p",
utype = "force",
scale = 0.00980665,
default = "mN oz-f",
link = "Kilogram-force",
},
["pdl"] = {
name1 = "poundal",
symbol = "pdl",
utype = "force",
scale = 0.138254954376,
default = "N",
},
["S/T-f"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "S/T<sub>f</sub>",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["S/Tf"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "S/Tf",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["ST-f"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "ST<sub>f</sub>",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["STf"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "STf",
usename = 1,
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["t-f"] = {
name1 = "tonne-force",
name2 = "tonnes-force",
symbol = "t<sub>f</sub>",
utype = "force",
scale = 9806.65,
default = "kN LT-f ST-f",
link = "Ton-force#Tonne-force",
},
["tf"] = {
name1 = "tonne-force",
name2 = "tonnes-force",
symbol = "tf",
utype = "force",
scale = 9806.65,
default = "kN LTf STf",
link = "Ton-force#Tonne-force",
},
["dyne"] = {
target = "dyn",
},
["newtons"] = {
target = "N",
},
["poundal"] = {
target = "pdl",
},
["tonne-force"] = {
target = "tf",
},
["impgal/mi"] = {
per = { "@impgal", "mi" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "L/km USgal/mi",
},
["km/L"] = {
per = { "km", "L" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "mpgimp mpgus",
},
["km/l"] = {
per = { "km", "ll" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "mpgimp mpgus",
},
["L/100 km"] = {
per = { "L", "100km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
symlink = "[[Fuel economy in automobiles#Units of measure|L/100 km]]",
},
["l/100 km"] = {
per = { "ll", "100km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
symlink = "[[Fuel economy in automobiles#Units of measure|l/100 km]]",
},
["L/km"] = {
per = { "L", "km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
},
["l/km"] = {
per = { "ll", "km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
},
["mi/impqt"] = {
per = { "mi", "impqt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mi/U.S.qt"] = {
per = { "mi", "U.S.qt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mi/USqt"] = {
per = { "mi", "USqt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mi/usqt"] = {
per = { "mi", "usqt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mpgimp"] = {
per = { "mi", "@impgal" },
symbol = "mpg<sub>‑imp</sub>",
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "L/100 km+mpgus",
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[Imperial units|imp]]</sub>",
},
["mpgus"] = {
per = { "mi", "+USgal" },
symbol = "mpg<sub>‑US</sub>",
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "L/100 km+mpgimp",
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[United States customary units|US]]</sub>",
},
["U.S.gal/mi"] = {
per = { "*U.S.gal", "mi" },
sp_us = true,
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "L/km impgal/mi",
},
["usgal/mi"] = {
per = { "+USgal", "mi" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "L/km impgal/mi",
},
["L/100km"] = {
target = "L/100 km",
},
["l/100km"] = {
target = "l/100 km",
},
["mpg"] = {
shouldbe = "Use %{mpgus%} for miles per US gallon or %{mpgimp%} for miles per imperial gallon (not %{mpg%})",
},
["mpgU.S."] = {
target = "mpgus",
symbol = "mpg<sub>‑U.S.</sub>",
sp_us = true,
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[United States customary units|U.S.]]</sub>",
},
["mpgu.s."] = {
target = "mpgus",
symbol = "mpg<sub>‑U.S.</sub>",
sp_us = true,
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[United States customary units|U.S.]]</sub>",
},
["mpgUS"] = {
target = "mpgus",
},
["USgal/mi"] = {
target = "usgal/mi",
},
["kPa/m"] = {
per = { "kPa", "-m-frac" },
utype = "fracture gradient",
default = "psi/ft",
},
["psi/ft"] = {
per = { "psi", "-ft-frac" },
utype = "fracture gradient",
default = "kPa/m",
},
["cm/km"] = {
name1 = "centimetre per kilometre",
name1_us = "centimeter per kilometer",
name2 = "centimetres per kilometre",
name2_us = "centimeters per kilometer",
symbol = "cm/km",
utype = "gradient",
scale = 0.00001,
default = "ft/mi",
link = "Grade (slope)",
},
["ft/mi"] = {
name1 = "foot per mile",
name2 = "feet per mile",
symbol = "ft/mi",
utype = "gradient",
scale = 0.00018939393939393939,
default = "v < 5.28 ! c ! ! m/km",
link = "Grade (slope)",
},
["ft/nmi"] = {
name1 = "foot per nautical mile",
name2 = "feet per nautical mile",
symbol = "ft/nmi",
utype = "gradient",
scale = 0.00016457883369330455,
default = "v < 6.076 ! c ! ! m/km",
link = "Grade (slope)",
},
["in/ft"] = {
name1 = "inch per foot",
name2 = "inches per foot",
symbol = "in/ft",
utype = "gradient",
scale = 0.083333333333333329,
default = "mm/m",
link = "Grade (slope)",
},
["in/mi"] = {
name1 = "inch per mile",
name2 = "inches per mile",
symbol = "in/mi",
utype = "gradient",
scale = 1.5782828282828283e-5,
default = "v < 0.6336 ! m ! c ! m/km",
link = "Grade (slope)",
},
["m/km"] = {
name1 = "metre per kilometre",
name1_us = "meter per kilometer",
name2 = "metres per kilometre",
name2_us = "meters per kilometer",
symbol = "m/km",
utype = "gradient",
scale = 0.001,
default = "ft/mi",
link = "Grade (slope)",
},
["mm/km"] = {
name1 = "millimetre per kilometre",
name1_us = "millimeter per kilometer",
name2 = "millimetres per kilometre",
name2_us = "millimeters per kilometer",
symbol = "mm/km",
utype = "gradient",
scale = 0.000001,
default = "in/mi",
link = "Grade (slope)",
},
["mm/m"] = {
name1 = "millimetre per metre",
name1_us = "millimeter per meter",
name2 = "millimetres per metre",
name2_us = "millimeters per meter",
symbol = "mm/m",
utype = "gradient",
scale = 0.001,
default = "in/ft",
link = "Grade (slope)",
},
["admi"] = {
name1 = "admiralty mile",
symbol = "nmi (admiralty)",
utype = "length",
scale = 1853.184,
default = "km mi",
link = "Nautical mile",
},
["AU"] = {
name1 = "astronomical unit",
symbol = "AU",
utype = "length",
scale = 149597870700,
default = "km mi",
},
["Brnmi"] = {
name1 = "British nautical mile",
symbol = "(Brit) nmi",
utype = "length",
scale = 1853.184,
default = "km mi",
link = "Nautical mile",
},
["bu"] = {
name2 = "bu",
symbol = "bu",
usename = 1,
utype = "length",
scale = 0.0030303030303030303,
default = "mm",
link = "Japanese units of measurement#Length",
},
["ch"] = {
name1 = "chain",
symbol = "ch",
utype = "length",
scale = 20.1168,
default = "ft m",
subdivs = { ["ft"] = { 66, default = "m" }, ["yd"] = { 22, default = "m" } },
link = "Chain (unit)",
},
["chlk"] = {
name1 = "[[Chain (unit)|chain]]",
symbol = "[[Chain (unit)|ch]]",
utype = "length",
scale = 20.1168,
default = "ft m",
link = "",
},
["chain"] = {
symbol = "chain",
usename = 1,
utype = "length",
scale = 20.1168,
default = "ft m",
subdivs = { ["ft"] = { 66, default = "m" }, ["yd"] = { 22, default = "m" } },
link = "Chain (unit)",
},
["chainlk"] = {
symbol = "[[Chain (unit)|chain]]",
usename = 1,
utype = "length",
scale = 20.1168,
default = "ft m",
link = "",
},
["dpcm"] = {
name2 = "dot/cm",
symbol = "dot/cm",
utype = "length",
scale = 100,
invert = -1,
iscomplex= true,
default = "dpi",
link = "Dots per inch",
},
["dpi"] = {
name2 = "DPI",
symbol = "DPI",
utype = "length",
scale = 39.370078740157481,
invert = -1,
iscomplex= true,
default = "pitch",
link = "Dots per inch",
},
["fathom"] = {
symbol = "fathom",
usename = 1,
utype = "length",
scale = 1.8288,
default = "ft m",
},
["foot"] = {
name1 = "foot",
name2 = "foot",
symbol = "ft",
utype = "length",
scale = 0.3048,
default = "m",
subdivs = { ["in"] = { 12, default = "m" } },
link = "Foot (unit)",
},
["ft"] = {
name1 = "foot",
name2 = "feet",
symbol = "ft",
utype = "length",
scale = 0.3048,
exception= "integer_more_precision",
default = "m",
subdivs = { ["in"] = { 12, default = "m" } },
link = "Foot (unit)",
},
["furlong"] = {
symbol = "furlong",
usename = 1,
utype = "length",
scale = 201.168,
default = "ft m",
},
["Gly"] = {
name1 = "gigalight-year",
symbol = "Gly",
utype = "length",
scale = 9.4607304725808e24,
default = "Mpc",
link = "Light-year#Definitions",
},
["Gpc"] = {
name1 = "gigaparsec",
symbol = "Gpc",
utype = "length",
scale = 3.0856775814671916e25,
default = "Gly",
link = "Parsec#Megaparsecs and gigaparsecs",
},
["hand"] = {
name1 = "hand",
symbol = "h",
utype = "length",
builtin = "hand",
scale = 0.1016,
iscomplex= true,
default = "in cm",
link = "Hand (unit)",
},
["in"] = {
name1 = "inch",
name2 = "inches",
symbol = "in",
utype = "length",
scale = 0.0254,
exception= "subunit_more_precision",
default = "mm",
},
["inabbreviated"] = {
name2 = "in",
symbol = "in",
utype = "length",
scale = 0.0254,
default = "mm",
link = "Inch",
},
["kly"] = {
name1 = "kilolight-year",
symbol = "kly",
utype = "length",
scale = 9.4607304725808e18,
default = "pc",
link = "Light-year#Definitions",
},
["kpc"] = {
name1 = "kiloparsec",
symbol = "kpc",
utype = "length",
scale = 3.0856775814671916e19,
default = "kly",
link = "Parsec#Parsecs and kiloparsecs",
},
["LD"] = {
name1 = "lunar distance",
symbol = "LD",
utype = "length",
scale = 384403000,
default = "km mi",
link = "Lunar distance (astronomy)",
},
["league"] = {
symbol = "league",
usename = 1,
utype = "length",
scale = 4828.032,
default = "km",
link = "League (unit)",
},
["ly"] = {
name1 = "light-year",
symbol = "ly",
utype = "length",
scale = 9.4607304725808e15,
default = "AU",
},
["m"] = {
_name1 = "metre",
_name1_us= "meter",
_symbol = "m",
utype = "length",
scale = 1,
prefixes = 1,
default = "v > 0 and v < 3 ! ftin ! ft",
link = "Metre",
},
["mi"] = {
name1 = "mile",
symbol = "mi",
utype = "length",
scale = 1609.344,
default = "km",
subdivs = { ["ch"] = { 80, default = "km" }, ["chlk"] = { 80, default = "km" }, ["chain"] = { 80, default = "km" }, ["chainlk"] = { 80, default = "km" }, ["ft"] = { 5280, default = "km" }, ["furlong"] = { 8, default = "km" }, ["yd"] = { 1760, default = "km" } },
},
["mil"] = {
symbol = "mil",
usename = 1,
utype = "length",
scale = 0.0000254,
default = "mm",
link = "Thousandth of an inch",
},
["Mly"] = {
name1 = "megalight-year",
symbol = "Mly",
utype = "length",
scale = 9.4607304725808e21,
default = "kpc",
link = "Light-year#Definitions",
},
["Mpc"] = {
name1 = "megaparsec",
symbol = "Mpc",
utype = "length",
scale = 3.0856775814671916e22,
default = "Mly",
link = "Parsec#Megaparsecs and gigaparsecs",
},
["NM"] = {
name1 = "nautical mile",
symbol = "NM",
utype = "length",
scale = 1852,
default = "km mi",
},
["nmi"] = {
name1 = "nautical mile",
symbol = "nmi",
utype = "length",
scale = 1852,
default = "km mi",
},
["oldUKnmi"] = {
name1 = "nautical mile",
symbol = "nmi",
utype = "length",
scale = 1853.184,
default = "km mi",
},
["oldUSnmi"] = {
name1 = "nautical mile",
symbol = "nmi",
utype = "length",
scale = 1853.24496,
default = "km mi",
},
["pc"] = {
name1 = "parsec",
symbol = "pc",
utype = "length",
scale = 3.0856775814671916e16,
default = "ly",
},
["perch"] = {
name2 = "perches",
symbol = "perch",
usename = 1,
utype = "length",
scale = 5.0292,
default = "ft m",
link = "Rod (unit)",
},
["pitch"] = {
name2 = "μm",
symbol = "μm",
utype = "length",
scale = 1e-6,
default = "dpi",
defkey = "pitch",
linkey = "pitch",
link = "Dots per inch",
},
["pole"] = {
symbol = "pole",
usename = 1,
utype = "length",
scale = 5.0292,
default = "ft m",
link = "Rod (unit)",
},
["pre1954U.S.nmi"] = {
name1 = "(pre-1954 U.S.) nautical mile",
symbol = "(pre‑1954 U.S.) nmi",
utype = "length",
scale = 1853.24496,
default = "km mi",
link = "Nautical mile",
},
["pre1954USnmi"] = {
name1 = "(pre-1954 US) nautical mile",
name1_us = "(pre-1954 U.S.) nautical mile",
symbol = "(pre‑1954 US) nmi",
sym_us = "(pre‑1954 U.S.) nmi",
utype = "length",
scale = 1853.24496,
default = "km mi",
link = "Nautical mile",
},
["rd"] = {
name1 = "rod",
symbol = "rd",
utype = "length",
scale = 5.0292,
default = "ft m",
link = "Rod (unit)",
},
["royal cubit"] = {
name1 = "royal cubit",
symbol = "cu",
utype = "length",
scale = 0.524,
default = "mm",
},
["rtkm"] = {
name1 = "route kilometre",
name1_us = "route kilometer",
symbol = "km",
utype = "length",
scale = 1000,
default = "mi",
link = "Kilometre",
},
["rtmi"] = {
name1 = "route mile",
symbol = "mi",
utype = "length",
scale = 1609.344,
default = "km",
link = "Mile",
},
["shaku"] = {
name2 = "shaku",
symbol = "shaku",
usename = 1,
utype = "length",
scale = 0.30303030303030304,
default = "m",
link = "Shaku (unit)",
},
["sm"] = {
name1 = "smoot",
symbol = "sm",
utype = "length",
scale = 1.70180,
default = "m",
link = "Smoot (unit)",
},
["smi"] = {
name1 = "statute mile",
symbol = "mi",
utype = "length",
scale = 1609.344,
default = "km",
subdivs = { ["chain"] = { 80, default = "km" } },
},
["solar radius"] = {
name1 = "solar radius",
name2 = "solar radii",
symbol = "''R''<sub>☉</sub>",
utype = "length",
scale = 695700e3,
default = "km",
},
["sun"] = {
name2 = "sun",
symbol = "sun",
usename = 1,
utype = "length",
scale = 0.030303030303030304,
default = "mm",
link = "Japanese units of measurement#Length",
},
["thou"] = {
name2 = "thou",
symbol = "thou",
usename = 1,
utype = "length",
scale = 0.0000254,
default = "mm",
link = "Thousandth of an inch",
},
["verst"] = {
symbol = "verst",
usename = 1,
utype = "length",
scale = 1066.8,
default = "km mi",
},
["yd"] = {
name1 = "yard",
symbol = "yd",
utype = "length",
scale = 0.9144,
default = "m",
subdivs = { ["ft"] = { 3, default = "m" } },
},
["μin"] = {
name1 = "microinch",
name2 = "microinches",
symbol = "μin",
utype = "length",
scale = 0.0000000254,
default = "nm",
link = "SI prefix#Non-metric units",
},
["Å"] = {
name1 = "ångström",
symbol = "Å",
utype = "length",
scale = 0.0000000001,
default = "in",
},
["Hz"] = {
_name1 = "hertz",
_name2 = "hertz",
_symbol = "Hz",
utype = "length",
scale = 3.3356409519815204e-9,
invert = -1,
iscomplex= true,
prefixes = 1,
default = "m",
link = "Hertz",
},
["rpm"] = {
name1 = "revolution per minute",
name2 = "revolutions per minute",
symbol = "rpm",
utype = "length",
scale = 5.5594015866358675e-11,
invert = -1,
iscomplex= true,
default = "Hz",
link = "Revolutions per minute",
},
["-ft-frac"] = {
target = "ft",
link = "Fracture gradient",
},
["-in-stiff"] = {
target = "in",
link = "Stiffness",
},
["-m-frac"] = {
target = "m",
link = "Fracture gradient",
},
["-m-stiff"] = {
target = "m",
link = "Stiffness",
},
["100km"] = {
target = "km",
multiplier= 100,
},
["100mi"] = {
target = "mi",
multiplier= 100,
},
["100miles"] = {
target = "mi",
symbol = "miles",
multiplier= 100,
},
["admiralty nmi"] = {
target = "oldUKnmi",
},
["angstrom"] = {
target = "Å",
},
["au"] = {
target = "AU",
symbol = "au",
},
["feet"] = {
target = "ft",
},
["hands"] = {
target = "hand",
},
["inch"] = {
target = "in",
},
["inches"] = {
target = "in",
},
["light-year"] = {
target = "ly",
},
["meter"] = {
target = "m",
sp_us = true,
},
["meters"] = {
target = "m",
sp_us = true,
},
["metre"] = {
target = "m",
},
["metres"] = {
target = "m",
},
["micrometre"] = {
target = "μm",
},
["micron"] = {
target = "μm",
default = "μin",
},
["mile"] = {
target = "mi",
usename = 1,
},
["miles"] = {
target = "mi",
usename = 1,
},
["parsec"] = {
target = "pc",
},
["rod"] = {
target = "rd",
},
["smoot"] = {
target = "sm",
},
["uin"] = {
target = "μin",
},
["yard"] = {
target = "yd",
},
["yards"] = {
target = "yd",
},
["yds"] = {
target = "yd",
},
["dtex"] = {
name1 = "decitex",
name2 = "decitex",
symbol = "dtex",
utype = "linear density",
scale = 1e-7,
default = "lb/yd",
link = "Units of textile measurement#Units",
},
["kg/cm"] = {
name1 = "kilogram per centimetre",
name1_us = "kilogram per centimeter",
name2 = "kilograms per centimetre",
name2_us = "kilograms per centimeter",
symbol = "kg/cm",
utype = "linear density",
scale = 100,
default = "lb/yd",
link = "Linear density",
},
["kg/m"] = {
name1 = "kilogram per metre",
name1_us = "kilogram per meter",
name2 = "kilograms per metre",
name2_us = "kilograms per meter",
symbol = "kg/m",
utype = "linear density",
scale = 1,
default = "lb/yd",
link = "Linear density",
},
["lb/ft"] = {
name1 = "pound per foot",
name2 = "pounds per foot",
symbol = "lb/ft",
utype = "linear density",
scale = 1.4881639435695539,
default = "kg/m",
link = "Linear density",
},
["lb/yd"] = {
name1 = "pound per yard",
name2 = "pounds per yard",
symbol = "lb/yd",
utype = "linear density",
scale = 0.49605464785651798,
default = "kg/m",
link = "Linear density",
},
["G"] = {
_name1 = "gauss",
_name2 = "gauss",
_symbol = "G",
utype = "magnetic field strength",
scale = 0.0001,
prefixes = 1,
default = "T",
link = "Gauss (unit)",
},
["T"] = {
_name1 = "tesla",
_symbol = "T",
utype = "magnetic field strength",
scale = 1,
prefixes = 1,
default = "G",
link = "Tesla (unit)",
},
["A/m"] = {
name1 = "ampere per metre",
name1_us = "ampere per meter",
name2 = "amperes per metre",
name2_us = "amperes per meter",
symbol = "A/m",
utype = "magnetizing field",
scale = 1,
default = "Oe",
},
["kA/m"] = {
name1 = "kiloampere per metre",
name1_us = "kiloampere per meter",
name2 = "kiloamperes per metre",
name2_us = "kiloamperes per meter",
symbol = "kA/m",
utype = "magnetizing field",
scale = 1000,
default = "kOe",
link = "Ampere per metre",
},
["MA/m"] = {
name1 = "megaampere per metre",
name1_us = "megaampere per meter",
name2 = "megaamperes per metre",
name2_us = "megaamperes per meter",
symbol = "MA/m",
utype = "magnetizing field",
scale = 1e6,
default = "kOe",
link = "Ampere per metre",
},
["Oe"] = {
_name1 = "oersted",
_symbol = "Oe",
utype = "magnetizing field",
scale = 79.5774715,
prefixes = 1,
default = "kA/m",
link = "Oersted",
},
["-Lcwt"] = {
name1 = "hundredweight",
name2 = "hundredweight",
symbol = "cwt",
utype = "mass",
scale = 50.80234544,
default = "lb",
},
["-Scwt"] = {
name1 = "hundredweight",
name2 = "hundredweight",
symbol = "cwt",
utype = "mass",
scale = 45.359237,
default = "lb",
},
["-ST"] = {
name1 = "short ton",
symbol = "ST",
utype = "mass",
scale = 907.18474,
default = "t",
},
["carat"] = {
symbol = "carat",
usename = 1,
utype = "mass",
scale = 0.0002,
default = "g",
link = "Carat (mass)",
},
["drachm"] = {
name1_us = "dram",
symbol = "drachm",
usename = 1,
utype = "mass",
scale = 0.001771845195,
default = "g",
link = "Dram (unit)",
},
["dram"] = {
target = "drachm",
},
["dwt"] = {
name1 = "pennyweight",
symbol = "dwt",
utype = "mass",
scale = 0.00155517384,
default = "oz g",
},
["DWton"] = {
symbol = "deadweight ton",
usename = 1,
utype = "mass",
scale = 1016.0469088,
default = "DWtonne",
link = "Deadweight tonnage",
},
["DWtonne"] = {
name1_us = "deadweight metric ton",
symbol = "deadweight tonne",
sym_us = "~deadweight metric ton",
usename = 1,
utype = "mass",
scale = 1000,
default = "DWton",
link = "Deadweight tonnage",
},
["g"] = {
_name1 = "gram",
_symbol = "g",
utype = "mass",
scale = 0.001,
prefixes = 1,
default = "oz",
link = "Gram",
},
["gr"] = {
name1 = "grain",
symbol = "gr",
utype = "mass",
scale = 0.00006479891,
default = "g",
link = "Grain (unit)",
},
["Gt"] = {
name1 = "gigatonne",
symbol = "Gt",
utype = "mass",
scale = 1000000000000,
default = "LT ST",
link = "Tonne",
},
["impgalh2o"] = {
name1 = "imperial gallon of water",
name2 = "imperial gallons of water",
symbol = "imp gal H<sub>2</sub>O",
utype = "mass",
scale = 4.5359236999999499,
default = "lb kg",
link = "Imperial gallon",
},
["kt"] = {
name1 = "kilotonne",
symbol = "kt",
utype = "mass",
scale = 1000000,
default = "LT ST",
link = "Tonne",
},
["lb"] = {
name1 = "pound",
symbol = "lb",
utype = "mass",
scale = 0.45359237,
exception= "integer_more_precision",
default = "kg",
subdivs = { ["oz"] = { 16, default = "kg" } },
link = "Pound (mass)",
},
["Lcwt"] = {
name1 = "long hundredweight",
name2 = "long hundredweight",
symbol = "Lcwt",
usename = 1,
utype = "mass",
scale = 50.80234544,
default = "lb",
subdivs = { ["qtr"] = { 4, default = "kg" }, ["st"] = { 8, default = "kg" } },
link = "Hundredweight",
},
["long cwt"] = {
name1 = "long hundredweight",
name2 = "long hundredweight",
symbol = "long cwt",
utype = "mass",
scale = 50.80234544,
default = "lb kg",
subdivs = { ["qtr"] = { 4, default = "kg" } },
link = "Hundredweight",
},
["long qtr"] = {
name1 = "long quarter",
symbol = "long qtr",
utype = "mass",
scale = 12.70058636,
default = "lb kg",
},
["LT"] = {
symbol = "long ton",
usename = 1,
utype = "mass",
scale = 1016.0469088,
default = "t",
subdivs = { ["Lcwt"] = { 20, default = "t", unit = "-Lcwt" } },
},
["lt"] = {
name1 = "long ton",
symbol = "LT",
utype = "mass",
scale = 1016.0469088,
default = "t",
subdivs = { ["Lcwt"] = { 20, default = "t", unit = "-Lcwt" } },
},
["metric ton"] = {
symbol = "metric ton",
usename = 1,
utype = "mass",
scale = 1000,
default = "long ton",
link = "Tonne",
},
["MT"] = {
name1 = "metric ton",
symbol = "t",
utype = "mass",
scale = 1000,
default = "LT ST",
link = "Tonne",
},
["Mt"] = {
name1 = "megatonne",
symbol = "Mt",
utype = "mass",
scale = 1000000000,
default = "LT ST",
link = "Tonne",
},
["oz"] = {
name1 = "ounce",
symbol = "oz",
utype = "mass",
scale = 0.028349523125,
default = "g",
},
["ozt"] = {
name1 = "troy ounce",
symbol = "ozt",
utype = "mass",
scale = 0.0311034768,
default = "oz g",
},
["pdr"] = {
name1 = "pounder",
symbol = "pdr",
utype = "mass",
scale = 0.45359237,
default = "kg",
link = "Pound (mass)",
},
["qtr"] = {
name1 = "quarter",
symbol = "qtr",
utype = "mass",
scale = 12.70058636,
default = "lb kg",
subdivs = { ["lb"] = { 28, default = "kg" } },
link = "Long quarter",
},
["Scwt"] = {
name1 = "short hundredweight",
name2 = "short hundredweight",
symbol = "Scwt",
usename = 1,
utype = "mass",
scale = 45.359237,
default = "lb",
link = "Hundredweight",
},
["short cwt"] = {
name1 = "short hundredweight",
name2 = "short hundredweight",
symbol = "short cwt",
utype = "mass",
scale = 45.359237,
default = "lb kg",
link = "Hundredweight",
},
["short qtr"] = {
name1 = "short quarter",
symbol = "short qtr",
utype = "mass",
scale = 11.33980925,
default = "lb kg",
},
["ST"] = {
symbol = "short ton",
usename = 1,
utype = "mass",
scale = 907.18474,
default = "t",
subdivs = { ["Scwt"] = { 20, default = "t", unit = "-Scwt" } },
},
["shtn"] = {
name1 = "short ton",
symbol = "sh tn",
utype = "mass",
scale = 907.18474,
default = "t",
},
["shton"] = {
symbol = "ton",
usename = 1,
utype = "mass",
scale = 907.18474,
default = "t",
},
["solar mass"] = {
name1 = "solar mass",
name2 = "solar masses",
symbol = "''M''<sub>☉</sub>",
utype = "mass",
scale = 1.98855e30,
default = "kg",
},
["st"] = {
name1 = "stone",
name2 = "stone",
symbol = "st",
utype = "mass",
scale = 6.35029318,
default = "lb kg",
subdivs = { ["lb"] = { 14, default = "kg lb" } },
link = "Stone (unit)",
},
["t"] = {
name1 = "tonne",
name1_us = "metric ton",
symbol = "t",
utype = "mass",
scale = 1000,
default = "LT ST",
},
["tonne"] = {
name1 = "tonne",
name1_us = "metric ton",
symbol = "t",
utype = "mass",
scale = 1000,
default = "shton",
},
["troy pound"] = {
symbol = "troy pound",
usename = 1,
utype = "mass",
scale = 0.3732417216,
default = "lb kg",
link = "Troy weight",
},
["usgalh2o"] = {
name1 = "US gallon of water",
name1_us = "U.S. gallon of water",
name2 = "US gallons of water",
name2_us = "U.S. gallons of water",
symbol = "US gal H<sub>2</sub>O",
utype = "mass",
scale = 3.7776215836051126,
default = "lb kg",
link = "United States customary units#Fluid volume",
},
["viss"] = {
name2 = "viss",
symbol = "viss",
utype = "mass",
scale = 1.632932532,
default = "kg",
link = "Myanmar units of measurement#Mass",
},
["billion tonne"] = {
target = "e9t",
},
["kilogram"] = {
target = "kg",
},
["kilotonne"] = {
target = "kt",
},
["lbs"] = {
target = "lb",
},
["lbt"] = {
target = "troy pound",
},
["lcwt"] = {
target = "Lcwt",
},
["long ton"] = {
target = "LT",
},
["mcg"] = {
target = "μg",
},
["million tonne"] = {
target = "e6t",
},
["scwt"] = {
target = "Scwt",
},
["short ton"] = {
target = "ST",
},
["stone"] = {
target = "st",
},
["thousand tonne"] = {
target = "e3t",
},
["tonnes"] = {
target = "t",
},
["kg/kW"] = {
name1 = "kilogram per kilowatt",
name2 = "kilograms per kilowatt",
symbol = "kg/kW",
utype = "mass per unit power",
scale = 0.001,
default = "lb/hp",
link = "Kilowatt",
},
["lb/hp"] = {
name1 = "pound per horsepower",
name2 = "pounds per horsepower",
symbol = "lb/hp",
utype = "mass per unit power",
scale = 0.00060827738784176115,
default = "kg/kW",
link = "Horsepower",
},
["kg/h"] = {
per = { "kg", "h" },
utype = "mass per unit time",
default = "lb/h",
},
["lb/h"] = {
per = { "lb", "h" },
utype = "mass per unit time",
default = "kg/h",
},
["g-mol/d"] = {
name1 = "gram-mole per day",
name2 = "gram-moles per day",
symbol = "g‑mol/d",
utype = "molar rate",
scale = 1.1574074074074073e-5,
default = "μmol/s",
link = "Mole (unit)",
},
["g-mol/h"] = {
name1 = "gram-mole per hour",
name2 = "gram-moles per hour",
symbol = "g‑mol/h",
utype = "molar rate",
scale = 0.00027777777777777778,
default = "mmol/s",
link = "Mole (unit)",
},
["g-mol/min"] = {
name1 = "gram-mole per minute",
name2 = "gram-moles per minute",
symbol = "g‑mol/min",
utype = "molar rate",
scale = 0.016666666666666666,
default = "g-mol/s",
link = "Mole (unit)",
},
["g-mol/s"] = {
name1 = "gram-mole per second",
name2 = "gram-moles per second",
symbol = "g‑mol/s",
utype = "molar rate",
scale = 1,
default = "lb-mol/min",
link = "Mole (unit)",
},
["gmol/d"] = {
name1 = "gram-mole per day",
name2 = "gram-moles per day",
symbol = "gmol/d",
utype = "molar rate",
scale = 1.1574074074074073e-5,
default = "μmol/s",
link = "Mole (unit)",
},
["gmol/h"] = {
name1 = "gram-mole per hour",
name2 = "gram-moles per hour",
symbol = "gmol/h",
utype = "molar rate",
scale = 0.00027777777777777778,
default = "mmol/s",
link = "Mole (unit)",
},
["gmol/min"] = {
name1 = "gram-mole per minute",
name2 = "gram-moles per minute",
symbol = "gmol/min",
utype = "molar rate",
scale = 0.016666666666666666,
default = "gmol/s",
link = "Mole (unit)",
},
["gmol/s"] = {
name1 = "gram-mole per second",
name2 = "gram-moles per second",
symbol = "gmol/s",
utype = "molar rate",
scale = 1,
default = "lbmol/min",
link = "Mole (unit)",
},
["kmol/d"] = {
name1 = "kilomole per day",
name2 = "kilomoles per day",
symbol = "kmol/d",
utype = "molar rate",
scale = 0.011574074074074073,
default = "mmol/s",
link = "Mole (unit)",
},
["kmol/h"] = {
name1 = "kilomole per hour",
name2 = "kilomoles per hour",
symbol = "kmol/h",
utype = "molar rate",
scale = 0.27777777777777779,
default = "mol/s",
link = "Mole (unit)",
},
["kmol/min"] = {
name1 = "kilomole per minute",
name2 = "kilomoles per minute",
symbol = "kmol/min",
utype = "molar rate",
scale = 16.666666666666668,
default = "mol/s",
link = "Kilomole (unit)",
},
["kmol/s"] = {
name1 = "kilomole per second",
name2 = "kilomoles per second",
symbol = "kmol/s",
utype = "molar rate",
scale = 1000,
default = "lb-mol/s",
link = "Mole (unit)",
},
["lb-mol/d"] = {
name1 = "pound-mole per day",
name2 = "pound-moles per day",
symbol = "lb‑mol/d",
utype = "molar rate",
scale = 0.0052499116898148141,
default = "mmol/s",
link = "Pound-mole",
},
["lb-mol/h"] = {
name1 = "pound-mole per hour",
name2 = "pound-moles per hour",
symbol = "lb‑mol/h",
utype = "molar rate",
scale = 0.12599788055555555,
default = "mol/s",
link = "Pound-mole",
},
["lb-mol/min"] = {
name1 = "pound-mole per minute",
name2 = "pound-moles per minute",
symbol = "lb‑mol/min",
utype = "molar rate",
scale = 7.5598728333333334,
default = "mol/s",
link = "Pound-mole",
},
["lb-mol/s"] = {
name1 = "pound-mole per second",
name2 = "pound-moles per second",
symbol = "lb‑mol/s",
utype = "molar rate",
scale = 453.59237,
default = "kmol/s",
link = "Pound-mole",
},
["lbmol/d"] = {
name1 = "pound-mole per day",
name2 = "pound-moles per day",
symbol = "lbmol/d",
utype = "molar rate",
scale = 0.0052499116898148141,
default = "mmol/s",
link = "Pound-mole",
},
["lbmol/h"] = {
name1 = "pound-mole per hour",
name2 = "pound-moles per hour",
symbol = "lbmol/h",
utype = "molar rate",
scale = 0.12599788055555555,
default = "mol/s",
link = "Pound-mole",
},
["lbmol/min"] = {
name1 = "pound-mole per minute",
name2 = "pound-moles per minute",
symbol = "lbmol/min",
utype = "molar rate",
scale = 7.5598728333333334,
default = "mol/s",
link = "Pound-mole",
},
["lbmol/s"] = {
name1 = "pound-mole per second",
name2 = "pound-moles per second",
symbol = "lbmol/s",
utype = "molar rate",
scale = 453.59237,
default = "kmol/s",
link = "Pound-mole",
},
["mmol/s"] = {
name1 = "millimole per second",
name2 = "millimoles per second",
symbol = "mmol/s",
utype = "molar rate",
scale = 0.001,
default = "lb-mol/d",
link = "Mole (unit)",
},
["mol/d"] = {
name1 = "mole per day",
name2 = "moles per day",
symbol = "mol/d",
utype = "molar rate",
scale = 1.1574074074074073e-5,
default = "μmol/s",
link = "Mole (unit)",
},
["mol/h"] = {
name1 = "mole per hour",
name2 = "moles per hour",
symbol = "mol/h",
utype = "molar rate",
scale = 0.00027777777777777778,
default = "mmol/s",
link = "Mole (unit)",
},
["mol/min"] = {
name1 = "mole per minute",
name2 = "moles per minute",
symbol = "mol/min",
utype = "molar rate",
scale = 0.016666666666666666,
default = "mol/s",
link = "Mole (unit)",
},
["mol/s"] = {
name1 = "mole per second",
name2 = "moles per second",
symbol = "mol/s",
utype = "molar rate",
scale = 1,
default = "lb-mol/min",
link = "Mole (unit)",
},
["μmol/s"] = {
name1 = "micromole per second",
name2 = "micromoles per second",
symbol = "μmol/s",
utype = "molar rate",
scale = 0.000001,
default = "lb-mol/d",
link = "Mole (unit)",
},
["umol/s"] = {
target = "μmol/s",
},
["/acre"] = {
name1 = "per acre",
name2 = "per acre",
symbol = "/acre",
utype = "per unit area",
scale = 0.00024710538146716532,
default = "/ha",
link = "Acre",
},
["/ha"] = {
name1 = "per hectare",
name2 = "per hectare",
symbol = "/ha",
utype = "per unit area",
scale = 100e-6,
default = "/acre",
link = "Hectare",
},
["/sqcm"] = {
name1 = "per square centimetre",
name1_us = "per square centimeter",
name2 = "per square centimetre",
name2_us = "per square centimeter",
symbol = "/cm<sup>2</sup>",
utype = "per unit area",
scale = 1e4,
default = "/sqin",
link = "Square centimetre",
},
["/sqin"] = {
name1 = "per square inch",
name2 = "per square inch",
symbol = "/in<sup>2</sup>",
utype = "per unit area",
scale = 1550.0031000062002,
default = "/sqcm",
link = "Square inch",
},
["/sqkm"] = {
name1 = "per square kilometre",
name1_us = "per square kilometer",
name2 = "per square kilometre",
name2_us = "per square kilometer",
symbol = "/km<sup>2</sup>",
utype = "per unit area",
scale = 1e-6,
default = "/sqmi",
link = "Square kilometre",
},
["/sqmi"] = {
name1 = "per square mile",
name2 = "per square mile",
symbol = "/sq mi",
utype = "per unit area",
scale = 3.8610215854244582e-7,
default = "/sqkm",
link = "Square mile",
},
["PD/acre"] = {
name1 = "inhabitant per acre",
name2 = "inhabitants per acre",
symbol = "/acre",
utype = "per unit area",
scale = 0.00024710538146716532,
default = "PD/ha",
link = "Acre",
},
["PD/ha"] = {
name1 = "inhabitant per hectare",
name2 = "inhabitants per hectare",
symbol = "/ha",
utype = "per unit area",
scale = 100e-6,
default = "PD/acre",
link = "Hectare",
},
["PD/sqkm"] = {
name1 = "inhabitant per square kilometre",
name1_us = "inhabitant per square kilometer",
name2 = "inhabitants per square kilometre",
name2_us = "inhabitants per square kilometer",
symbol = "/km<sup>2</sup>",
utype = "per unit area",
scale = 1e-6,
default = "PD/sqmi",
link = "Square kilometre",
},
["PD/sqmi"] = {
name1 = "inhabitant per square mile",
name2 = "inhabitants per square mile",
symbol = "/sq mi",
utype = "per unit area",
scale = 3.8610215854244582e-7,
default = "PD/sqkm",
link = "Square mile",
},
["/cm2"] = {
target = "/sqcm",
},
["/in2"] = {
target = "/sqin",
},
["/km2"] = {
target = "/sqkm",
},
["pd/acre"] = {
target = "PD/acre",
},
["pd/ha"] = {
target = "PD/ha",
},
["PD/km2"] = {
target = "PD/sqkm",
},
["pd/km2"] = {
target = "PD/sqkm",
},
["PD/km²"] = {
target = "PD/sqkm",
},
["pd/sqkm"] = {
target = "PD/sqkm",
},
["pd/sqmi"] = {
target = "PD/sqmi",
},
["/l"] = {
name1 = "per litre",
name1_us = "per liter",
name2 = "per litre",
name2_us = "per liter",
symbol = "/l",
utype = "per unit volume",
scale = 1000,
default = "/usgal",
link = "Litre",
},
["/L"] = {
name1 = "per litre",
name1_us = "per liter",
name2 = "per litre",
name2_us = "per liter",
symbol = "/L",
utype = "per unit volume",
scale = 1000,
default = "/usgal",
link = "Litre",
},
["/USgal"] = {
name1 = "per gallon",
name2 = "per gallon",
symbol = "/gal",
utype = "per unit volume",
scale = 264.172052,
default = "/L",
link = "US gallon",
customary= 2,
},
["/usgal"] = {
target = "/USgal",
},
["bhp"] = {
name1 = "brake horsepower",
name2 = "brake horsepower",
symbol = "bhp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
link = "Horsepower#Brake horsepower",
},
["Cal/d"] = {
name1 = "large calorie per day",
name2 = "large calories per day",
symbol = "Cal/d",
utype = "power",
scale = 0.048425925925925928,
default = "kJ/d",
link = "Calorie",
},
["Cal/h"] = {
name1 = "large calorie per hour",
name2 = "large calories per hour",
symbol = "Cal/h",
utype = "power",
scale = 1.1622222222222223,
default = "kJ/h",
link = "Calorie",
},
["cal/h"] = {
name1 = "calorie per hour",
name2 = "calories per hour",
symbol = "cal/h",
utype = "power",
scale = 0.0011622222222222223,
default = "W",
link = "Calorie",
},
["CV"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "CV",
utype = "power",
scale = 735.49875,
default = "kW",
},
["hk"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "hk",
utype = "power",
scale = 735.49875,
default = "kW",
},
["hp"] = {
name1 = "horsepower",
name2 = "horsepower",
symbol = "hp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
},
["hp-electric"] = {
name1 = "electric horsepower",
name2 = "electric horsepower",
symbol = "hp",
utype = "power",
scale = 746,
default = "kW",
link = "Horsepower#Electrical horsepower",
},
["hp-electrical"] = {
name1 = "electrical horsepower",
name2 = "electrical horsepower",
symbol = "hp",
utype = "power",
scale = 746,
default = "kW",
link = "Horsepower#Electrical horsepower",
},
["hp-metric"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "hp",
utype = "power",
scale = 735.49875,
default = "kW",
},
["ihp"] = {
name1 = "indicated horsepower",
name2 = "indicated horsepower",
symbol = "ihp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
link = "Horsepower#Indicated horsepower",
},
["kcal/h"] = {
name1 = "kilocalorie per hour",
name2 = "kilocalories per hour",
symbol = "kcal/h",
utype = "power",
scale = 1.1622222222222223,
default = "kW",
link = "Calorie",
},
["kJ/d"] = {
name1 = "kilojoule per day",
name2 = "kilojoules per day",
symbol = "kJ/d",
utype = "power",
scale = 0.011574074074074073,
default = "Cal/d",
link = "Kilojoule",
},
["kJ/h"] = {
name1 = "kilojoule per hour",
name2 = "kilojoules per hour",
symbol = "kJ/h",
utype = "power",
scale = 0.27777777777777779,
default = "W",
link = "Kilojoule",
},
["PS"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "PS",
utype = "power",
scale = 735.49875,
default = "kW",
},
["shp"] = {
name1 = "shaft horsepower",
name2 = "shaft horsepower",
symbol = "shp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
link = "Horsepower#Shaft horsepower",
},
["W"] = {
_name1 = "watt",
_symbol = "W",
utype = "power",
scale = 1,
prefixes = 1,
default = "hp",
link = "Watt",
},
["BTU/h"] = {
per = { "BTU", "h" },
utype = "power",
default = "W",
},
["Btu/h"] = {
per = { "Btu", "h" },
utype = "power",
default = "W",
},
["BHP"] = {
target = "bhp",
},
["btu/h"] = {
target = "BTU/h",
},
["HP"] = {
target = "hp",
},
["Hp"] = {
target = "hp",
},
["hp-mechanical"] = {
target = "hp",
},
["IHP"] = {
target = "ihp",
},
["SHP"] = {
target = "shp",
},
["whp"] = {
target = "hp",
},
["hp/lb"] = {
name1 = "horsepower per pound",
name2 = "horsepower per pound",
symbol = "hp/lb",
utype = "power per unit mass",
scale = 1643.986806,
default = "kW/kg",
link = "Power-to-weight ratio",
},
["hp/LT"] = {
name1 = "horsepower per long ton",
name2 = "horsepower per long ton",
symbol = "hp/LT",
utype = "power per unit mass",
scale = 0.73392268125000004,
default = "kW/t",
link = "Power-to-weight ratio",
},
["hp/ST"] = {
name1 = "horsepower per short ton",
name2 = "horsepower per short ton",
symbol = "hp/ST",
utype = "power per unit mass",
scale = 0.821993403,
default = "kW/t",
link = "Power-to-weight ratio",
},
["hp/t"] = {
name1 = "horsepower per tonne",
name2 = "horsepower per tonne",
symbol = "hp/t",
utype = "power per unit mass",
scale = 0.74569987158227022,
default = "kW/t",
link = "Power-to-weight ratio",
},
["kW/kg"] = {
name1 = "kilowatt per kilogram",
name2 = "kilowatts per kilogram",
symbol = "kW/kg",
utype = "power per unit mass",
scale = 1000,
default = "hp/lb",
link = "Power-to-weight ratio",
},
["kW/t"] = {
name1 = "kilowatt per tonne",
name2 = "kilowatts per tonne",
symbol = "kW/t",
utype = "power per unit mass",
scale = 1,
default = "PS/t",
link = "Power-to-weight ratio",
},
["PS/t"] = {
name1 = "metric horsepower per tonne",
name2 = "metric horsepower per tonne",
symbol = "PS/t",
utype = "power per unit mass",
scale = 0.73549875,
default = "kW/t",
link = "Power-to-weight ratio",
},
["shp/lb"] = {
name1 = "shaft horsepower per pound",
name2 = "shaft horsepower per pound",
symbol = "shp/lb",
utype = "power per unit mass",
scale = 1643.986806,
default = "kW/kg",
link = "Power-to-weight ratio",
},
["hp/tonne"] = {
target = "hp/t",
symbol = "hp/tonne",
default = "kW/tonne",
},
["kW/tonne"] = {
target = "kW/t",
symbol = "kW/tonne",
},
["-lb/in2"] = {
name1 = "pound per square inch",
name2 = "pounds per square inch",
symbol = "lb/in<sup>2</sup>",
utype = "pressure",
scale = 6894.7572931683608,
default = "kPa kgf/cm2",
},
["atm"] = {
name1 = "standard atmosphere",
symbol = "atm",
utype = "pressure",
scale = 101325,
default = "kPa",
link = "Atmosphere (unit)",
},
["Ba"] = {
name1 = "barye",
symbol = "Ba",
utype = "pressure",
scale = 0.1,
default = "Pa",
},
["bar"] = {
symbol = "bar",
utype = "pressure",
scale = 100000,
default = "kPa",
link = "Bar (unit)",
},
["dbar"] = {
name1 = "decibar",
symbol = "dbar",
utype = "pressure",
scale = 10000,
default = "kPa",
link = "Bar (unit)",
},
["inHg"] = {
name1 = "inch of mercury",
name2 = "inches of mercury",
symbol = "inHg",
utype = "pressure",
scale = 3386.388640341,
default = "kPa",
},
["kBa"] = {
name1 = "kilobarye",
symbol = "kBa",
utype = "pressure",
scale = 100,
default = "hPa",
link = "Barye",
},
["kg-f/cm2"] = {
name1 = "kilogram-force per square centimetre",
name1_us = "kilogram-force per square centimeter",
name2 = "kilograms-force per square centimetre",
name2_us = "kilograms-force per square centimeter",
symbol = "kg<sub>f</sub>/cm<sup>2</sup>",
utype = "pressure",
scale = 98066.5,
default = "psi",
link = "Kilogram-force",
},
["kg/cm2"] = {
name1 = "kilogram per square centimetre",
name1_us = "kilogram per square centimeter",
name2 = "kilograms per square centimetre",
name2_us = "kilograms per square centimeter",
symbol = "kg/cm<sup>2</sup>",
utype = "pressure",
scale = 98066.5,
default = "psi",
link = "Kilogram-force",
},
["kgf/cm2"] = {
name1 = "kilogram-force per square centimetre",
name1_us = "kilogram-force per square centimeter",
name2 = "kilograms-force per square centimetre",
name2_us = "kilograms-force per square centimeter",
symbol = "kgf/cm<sup>2</sup>",
utype = "pressure",
scale = 98066.5,
default = "psi",
link = "Kilogram-force",
},
["ksi"] = {
name1 = "kilopound per square inch",
name2 = "kilopounds per square inch",
symbol = "ksi",
utype = "pressure",
scale = 6894757.2931683613,
default = "MPa",
link = "Pound per square inch",
},
["lbf/in2"] = {
name1 = "pound-force per square inch",
name2 = "pounds-force per square inch",
symbol = "lbf/in<sup>2</sup>",
utype = "pressure",
scale = 6894.7572931683608,
default = "kPa kgf/cm2",
},
["mb"] = {
name1 = "millibar",
symbol = "mb",
utype = "pressure",
scale = 100,
default = "hPa",
link = "Bar (unit)",
},
["mbar"] = {
name1 = "millibar",
symbol = "mbar",
utype = "pressure",
scale = 100,
default = "hPa",
link = "Bar (unit)",
},
["mmHg"] = {
name1 = "millimetre of mercury",
name1_us = "millimeter of mercury",
name2 = "millimetres of mercury",
name2_us = "millimeters of mercury",
symbol = "mmHg",
utype = "pressure",
scale = 133.322387415,
default = "kPa",
},
["Pa"] = {
_name1 = "pascal",
_symbol = "Pa",
utype = "pressure",
scale = 1,
prefixes = 1,
default = "psi",
link = "Pascal (unit)",
},
["psf"] = {
name1 = "pound per square foot",
name2 = "pounds per square foot",
symbol = "psf",
utype = "pressure",
scale = 47.880258980335839,
default = "kPa",
link = "Pound per square inch",
},
["psi"] = {
name1 = "pound per square inch",
name2 = "pounds per square inch",
symbol = "psi",
utype = "pressure",
scale = 6894.7572931683608,
default = "kPa",
},
["Torr"] = {
name1 = "torr",
symbol = "Torr",
utype = "pressure",
scale = 133.32236842105263,
default = "kPa",
},
["N/cm2"] = {
per = { "N", "cm2" },
utype = "pressure",
default = "psi",
},
["N/m2"] = {
per = { "N", "m2" },
utype = "pressure",
default = "psi",
},
["g/cm2"] = {
per = { "g", "cm2" },
utype = "pressure",
default = "lb/sqft",
multiplier= 9.80665,
},
["g/m2"] = {
per = { "g", "m2" },
utype = "pressure",
default = "lb/sqft",
multiplier= 9.80665,
},
["kg/ha"] = {
per = { "kg", "ha" },
utype = "pressure",
default = "lb/acre",
multiplier= 9.80665,
},
["kg/m2"] = {
per = { "kg", "m2" },
utype = "pressure",
default = "lb/sqft",
multiplier= 9.80665,
},
["lb/1000sqft"] = {
per = { "lb", "1000sqft" },
utype = "pressure",
default = "g/m2",
multiplier= 9.80665,
},
["lb/acre"] = {
per = { "lb", "acre" },
utype = "pressure",
default = "kg/ha",
multiplier= 9.80665,
},
["lb/sqft"] = {
per = { "lb", "sqft" },
utype = "pressure",
default = "kg/m2",
multiplier= 9.80665,
},
["lb/sqyd"] = {
per = { "lb", "sqyd" },
utype = "pressure",
default = "kg/m2",
multiplier= 9.80665,
},
["LT/acre"] = {
per = { "LT", "acre" },
utype = "pressure",
default = "t/ha",
multiplier= 9.80665,
},
["MT/ha"] = {
per = { "MT", "ha" },
utype = "pressure",
default = "LT/acre ST/acre",
multiplier= 9.80665,
},
["oz/sqft"] = {
per = { "oz", "sqft" },
utype = "pressure",
default = "g/m2",
multiplier= 9.80665,
},
["oz/sqyd"] = {
per = { "oz", "sqyd" },
utype = "pressure",
default = "g/m2",
multiplier= 9.80665,
},
["ST/acre"] = {
per = { "ST", "acre" },
utype = "pressure",
default = "t/ha",
multiplier= 9.80665,
},
["t/ha"] = {
per = { "t", "ha" },
utype = "pressure",
default = "LT/acre ST/acre",
multiplier= 9.80665,
},
["tonne/acre"] = {
per = { "tonne", "acre" },
utype = "pressure",
default = "tonne/ha",
multiplier= 9.80665,
},
["tonne/ha"] = {
per = { "tonne", "ha" },
utype = "pressure",
default = "tonne/acre",
multiplier= 9.80665,
},
["kgfpsqcm"] = {
target = "kgf/cm2",
},
["kgpsqcm"] = {
target = "kg/cm2",
},
["kN/m2"] = {
target = "kPa",
},
["lb/in2"] = {
target = "lbf/in2",
},
["torr"] = {
target = "Torr",
},
["Bq"] = {
_name1 = "becquerel",
_symbol = "Bq",
utype = "radioactivity",
scale = 1,
prefixes = 1,
default = "pCi",
link = "Becquerel",
},
["Ci"] = {
_name1 = "curie",
_symbol = "Ci",
utype = "radioactivity",
scale = 3.7e10,
prefixes = 1,
default = "GBq",
link = "Curie (unit)",
},
["Rd"] = {
_name1 = "rutherford",
_symbol = "Rd",
utype = "radioactivity",
scale = 1e6,
prefixes = 1,
default = "MBq",
link = "Rutherford (unit)",
},
["cm/h"] = {
name1 = "centimetre per hour",
name1_us = "centimeter per hour",
name2 = "centimetres per hour",
name2_us = "centimeters per hour",
symbol = "cm/h",
utype = "speed",
scale = 2.7777777777777775e-6,
default = "in/h",
link = "Metre per second",
},
["cm/s"] = {
name1 = "centimetre per second",
name1_us = "centimeter per second",
name2 = "centimetres per second",
name2_us = "centimeters per second",
symbol = "cm/s",
utype = "speed",
scale = 0.01,
default = "in/s",
link = "Metre per second",
},
["cm/year"] = {
name1 = "centimetre per year",
name1_us = "centimeter per year",
name2 = "centimetres per year",
name2_us = "centimeters per year",
symbol = "cm/year",
utype = "speed",
scale = 3.168873850681143e-10,
default = "in/year",
link = "Orders of magnitude (speed)",
},
["foot/s"] = {
name1 = "foot per second",
name2 = "foot per second",
symbol = "ft/s",
utype = "speed",
scale = 0.3048,
default = "m/s",
},
["ft/min"] = {
name1 = "foot per minute",
name2 = "feet per minute",
symbol = "ft/min",
utype = "speed",
scale = 0.00508,
default = "m/min",
link = "Feet per second",
},
["ft/s"] = {
name1 = "foot per second",
name2 = "feet per second",
symbol = "ft/s",
utype = "speed",
scale = 0.3048,
default = "m/s",
link = "Feet per second",
},
["furlong per fortnight"] = {
name2 = "furlongs per fortnight",
symbol = "furlong per fortnight",
usename = 1,
utype = "speed",
scale = 0.00016630952380952381,
default = "km/h mph",
link = "FFF system",
},
["in/h"] = {
name1 = "inch per hour",
name2 = "inches per hour",
symbol = "in/h",
utype = "speed",
scale = 7.0555555555555559e-6,
default = "cm/h",
link = "Inch",
},
["in/s"] = {
name1 = "inch per second",
name2 = "inches per second",
symbol = "in/s",
utype = "speed",
scale = 0.0254,
default = "cm/s",
link = "Inch",
},
["in/year"] = {
name1 = "inch per year",
name2 = "inches per year",
symbol = "in/year",
utype = "speed",
scale = 8.0489395807301024e-10,
default = "cm/year",
link = "Orders of magnitude (speed)",
},
["isp"] = {
name1 = "second",
symbol = "s",
utype = "speed",
scale = 9.80665,
default = "km/s",
link = "Specific impulse",
},
["km/d"] = {
name1 = "kilometre per day",
name1_us = "kilometer per day",
name2 = "kilometres per day",
name2_us = "kilometers per day",
symbol = "km/d",
utype = "speed",
scale = 1.1574074074074074e-2,
default = "mi/d",
link = "Orders of magnitude (speed)",
},
["km/h"] = {
name1 = "kilometre per hour",
name1_us = "kilometer per hour",
name2 = "kilometres per hour",
name2_us = "kilometers per hour",
symbol = "km/h",
utype = "speed",
scale = 0.27777777777777779,
default = "mph",
link = "Kilometres per hour",
},
["km/s"] = {
name1 = "kilometre per second",
name1_us = "kilometer per second",
name2 = "kilometres per second",
name2_us = "kilometers per second",
symbol = "km/s",
utype = "speed",
scale = 1000,
default = "mi/s",
link = "Metre per second",
},
["kn"] = {
name1 = "knot",
symbol = "kn",
utype = "speed",
scale = 0.51444444444444448,
default = "km/h mph",
link = "Knot (unit)",
},
["kNs/kg"] = {
name2 = "kN‑s/kg",
symbol = "kN‑s/kg",
utype = "speed",
scale = 1000,
default = "isp",
link = "Specific impulse",
},
["m/min"] = {
name1 = "metre per minute",
name1_us = "meter per minute",
name2 = "metres per minute",
name2_us = "meters per minute",
symbol = "m/min",
utype = "speed",
scale = 0.016666666666666666,
default = "ft/min",
link = "Metre per second",
},
["m/s"] = {
name1 = "metre per second",
name1_us = "meter per second",
name2 = "metres per second",
name2_us = "meters per second",
symbol = "m/s",
utype = "speed",
scale = 1,
default = "ft/s",
},
["Mach"] = {
name2 = "Mach",
symbol = "Mach",
utype = "speed",
builtin = "mach",
scale = 0,
iscomplex= true,
default = "km/h mph",
link = "Mach number",
},
["mi/d"] = {
name1 = "mile per day",
name2 = "miles per day",
symbol = "mi/d",
utype = "speed",
scale = 1.8626666666666667e-2,
default = "km/d",
link = "Orders of magnitude (speed)",
},
["mi/s"] = {
name1 = "mile per second",
name2 = "miles per second",
symbol = "mi/s",
utype = "speed",
scale = 1609.344,
default = "km/s",
link = "Mile",
},
["mm/h"] = {
name1 = "millimetre per hour",
name1_us = "millimeter per hour",
name2 = "millimetres per hour",
name2_us = "millimeters per hour",
symbol = "mm/h",
utype = "speed",
scale = 2.7777777777777781e-7,
default = "in/h",
link = "Metre per second",
},
["mph"] = {
name1 = "mile per hour",
name2 = "miles per hour",
symbol = "mph",
utype = "speed",
scale = 0.44704,
default = "km/h",
link = "Miles per hour",
},
["Ns/kg"] = {
name2 = "N‑s/kg",
symbol = "N‑s/kg",
utype = "speed",
scale = 1,
default = "isp",
link = "Specific impulse",
},
["si tsfc"] = {
name2 = "g/(kN⋅s)",
symbol = "g/(kN⋅s)",
utype = "speed",
scale = 9.9999628621379242e-7,
invert = -1,
iscomplex= true,
default = "tsfc",
link = "Thrust specific fuel consumption",
},
["tsfc"] = {
name2 = "lb/(lbf⋅h)",
symbol = "lb/(lbf⋅h)",
utype = "speed",
scale = 2.832545036049801e-5,
invert = -1,
iscomplex= true,
default = "si tsfc",
link = "Thrust specific fuel consumption",
},
["cm/y"] = {
target = "cm/year",
},
["cm/yr"] = {
target = "cm/year",
},
["in/y"] = {
target = "in/year",
},
["in/yr"] = {
target = "in/year",
},
["knot"] = {
target = "kn",
},
["knots"] = {
target = "kn",
},
["kph"] = {
target = "km/h",
},
["mi/h"] = {
target = "mph",
},
["mm/s"] = {
per = { "mm", "s" },
utype = "speed",
default = "in/s",
link = "Metre per second",
},
["C"] = {
name1 = "degree Celsius",
name2 = "degrees Celsius",
symbol = "°C",
usesymbol= 1,
utype = "temperature",
scale = 1,
offset = -273.15,
iscomplex= true,
istemperature= true,
default = "F",
link = "Celsius",
},
["F"] = {
name1 = "degree Fahrenheit",
name2 = "degrees Fahrenheit",
symbol = "°F",
usesymbol= 1,
utype = "temperature",
scale = 0.55555555555555558,
offset = 32-273.15*(9/5),
iscomplex= true,
istemperature= true,
default = "C",
link = "Fahrenheit",
},
["K"] = {
_name1 = "kelvin",
_symbol = "K",
usesymbol= 1,
utype = "temperature",
scale = 1,
offset = 0,
iscomplex= true,
istemperature= true,
prefixes = 1,
default = "C F",
link = "Kelvin",
},
["keVT"] = {
name1 = "kiloelectronvolt",
symbol = "keV",
utype = "temperature",
scale = 11.604505e6,
offset = 0,
iscomplex= true,
default = "MK",
link = "Electronvolt",
},
["R"] = {
name1 = "degree Rankine",
name2 = "degrees Rankine",
symbol = "°R",
usesymbol= 1,
utype = "temperature",
scale = 0.55555555555555558,
offset = 0,
iscomplex= true,
istemperature= true,
default = "K F C",
link = "Rankine scale",
},
["Celsius"] = {
target = "C",
},
["°C"] = {
target = "C",
},
["°F"] = {
target = "F",
},
["°R"] = {
target = "R",
},
["C-change"] = {
name1 = "degree Celsius change",
name2 = "degrees Celsius change",
symbol = "°C",
usesymbol= 1,
utype = "temperature change",
scale = 1,
default = "F-change",
link = "Celsius",
},
["F-change"] = {
name1 = "degree Fahrenheit change",
name2 = "degrees Fahrenheit change",
symbol = "°F",
usesymbol= 1,
utype = "temperature change",
scale = 0.55555555555555558,
default = "C-change",
link = "Fahrenheit",
},
["K-change"] = {
name1 = "kelvin change",
name2 = "kelvins change",
symbol = "K",
usesymbol= 1,
utype = "temperature change",
scale = 1,
default = "F-change",
link = "Kelvin",
},
["°C-change"] = {
target = "C-change",
},
["°F-change"] = {
target = "F-change",
},
["century"] = {
name1 = "century",
name2 = "centuries",
symbol = "ha",
utype = "time",
scale = 3155760000,
default = "Gs",
},
["d"] = {
name1 = "day",
symbol = "d",
utype = "time",
scale = 86400,
default = "ks",
},
["decade"] = {
name1 = "decade",
symbol = "daa",
utype = "time",
scale = 315576000,
default = "Ms",
},
["dog year"] = {
name1 = "dog year",
symbol = "dog yr",
utype = "time",
scale = 220903200,
default = "years",
link = "List of unusual units of measurement#Dog year",
},
["fortnight"] = {
symbol = "fortnight",
usename = 1,
utype = "time",
scale = 1209600,
default = "week",
},
["h"] = {
name1 = "hour",
symbol = "h",
utype = "time",
scale = 3600,
default = "ks",
},
["long billion year"] = {
name1 = "billion years",
name2 = "billion years",
symbol = "Ta",
utype = "time",
scale = 31557600000000000000,
default = "Es",
link = "Annum",
},
["millennium"] = {
name1 = "millennium",
name2 = "millennia",
symbol = "ka",
utype = "time",
scale = 31557600000,
default = "Gs",
},
["milliard year"] = {
name1 = "milliard years",
name2 = "milliard years",
symbol = "Ga",
utype = "time",
scale = 31557600000000000,
default = "Ps",
link = "Annum",
},
["million year"] = {
name1 = "million years",
name2 = "million years",
symbol = "Ma",
utype = "time",
scale = 31557600000000,
default = "Ts",
link = "Annum",
},
["min"] = {
name1 = "minute",
symbol = "min",
utype = "time",
scale = 60,
default = "s",
},
["month"] = {
symbol = "month",
usename = 1,
utype = "time",
scale = 2629800,
default = "Ms",
},
["months"] = {
name1 = "month",
symbol = "mo",
utype = "time",
scale = 2629800,
default = "year",
},
["s"] = {
_name1 = "second",
_symbol = "s",
utype = "time",
scale = 1,
prefixes = 1,
default = "v < 7200 ! min ! h",
link = "Second",
},
["short billion year"] = {
name1 = "billion years",
name2 = "billion years",
symbol = "Ga",
utype = "time",
scale = 31557600000000000,
default = "Ps",
link = "Annum",
},
["short trillion year"] = {
name1 = "trillion years",
name2 = "trillion years",
symbol = "Ta",
utype = "time",
scale = 31557600000000000000,
default = "Es",
link = "Annum",
},
["thousand million year"] = {
name1 = "thousand million years",
name2 = "thousand million years",
symbol = "Ga",
utype = "time",
scale = 31557600000000000,
default = "Ps",
link = "Annum",
},
["wk"] = {
symbol = "week",
usename = 1,
utype = "time",
scale = 604800,
default = "Ms",
},
["year"] = {
name1 = "year",
symbol = "a",
utype = "time",
scale = 31557600,
default = "Ms",
link = "Annum",
},
["years"] = {
name1 = "year",
symbol = "yr",
utype = "time",
scale = 31557600,
default = "Ms",
link = "Annum",
},
["byr"] = {
target = "short billion year",
},
["day"] = {
target = "d",
},
["days"] = {
target = "d",
},
["dog yr"] = {
target = "dog year",
},
["Gyr"] = {
target = "thousand million year",
},
["hour"] = {
target = "h",
},
["hours"] = {
target = "h",
},
["kMyr"] = {
target = "thousand million year",
},
["kmyr"] = {
target = "thousand million year",
},
["kyr"] = {
target = "millennium",
},
["long byr"] = {
target = "long billion year",
},
["minute"] = {
target = "min",
},
["minutes"] = {
target = "min",
},
["mth"] = {
target = "month",
},
["Myr"] = {
target = "million year",
},
["myr"] = {
target = "million year",
},
["sec"] = {
target = "s",
},
["second"] = {
target = "s",
},
["seconds"] = {
target = "s",
},
["tmyr"] = {
target = "thousand million year",
},
["tryr"] = {
target = "short trillion year",
},
["tyr"] = {
target = "millennium",
},
["week"] = {
target = "wk",
},
["weeks"] = {
target = "wk",
},
["yr"] = {
target = "year",
},
["kg.m"] = {
name1 = "kilogram metre",
name1_us = "kilogram meter",
symbol = "kg⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbft",
link = "Kilogram metre (torque)",
},
["kgf.m"] = {
name1 = "kilogram force-metre",
name1_us = "kilogram force-meter",
symbol = "kgf⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["kgm"] = {
name1 = "kilogram metre",
name1_us = "kilogram meter",
symbol = "kg⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["kpm"] = {
name1 = "kilopond metre",
name1_us = "kilopond meter",
symbol = "kp⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbft",
link = "Kilogram metre (torque)",
},
["lb-fft"] = {
name1 = "pound force-foot",
name2 = "pound force-feet",
symbol = "ft⋅lb<sub>f</sub>",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["lb.ft"] = {
name1 = "pound force-foot",
name2 = "pound force-feet",
symbol = "lb⋅ft",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["lb.in"] = {
name1 = "pound force-inch",
symbol = "lb⋅in",
utype = "torque",
scale = 0.1129848290276167,
default = "mN.m",
link = "Pound-foot (torque)",
},
["lbfft"] = {
name1 = "pound force-foot",
name2 = "pound force-feet",
symbol = "lbf⋅ft",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["lbft"] = {
name1 = "pound-foot",
name2 = "pound-feet",
symbol = "lb⋅ft",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["m.kg-f"] = {
name1 = "metre kilogram-force",
name1_us = "meter kilogram-force",
name2 = "metre kilograms-force",
name2_us = "meter kilograms-force",
symbol = "m⋅kg<sub>f</sub>",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["m.kgf"] = {
name1 = "metre kilogram-force",
name1_us = "meter kilogram-force",
name2 = "metre kilograms-force",
name2_us = "meter kilograms-force",
symbol = "m⋅kgf",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["mN.m"] = {
name1 = "millinewton-metre",
name1_us = "millinewton-meter",
symbol = "mN⋅m",
utype = "torque",
scale = 0.001,
default = "lb.in",
link = "Newton-metre",
},
["Nm"] = {
_name1 = "newton-metre",
_name1_us= "newton-meter",
_symbol = "N⋅m",
utype = "torque",
alttype = "energy",
scale = 1,
prefixes = 1,
default = "lbfft",
link = "Newton-metre",
},
["kN/m"] = {
per = { "kN", "-m-stiff" },
utype = "torque",
default = "lbf/in",
},
["lbf/in"] = {
per = { "lbf", "-in-stiff" },
utype = "torque",
default = "kN/m",
},
["lb-f.ft"] = {
target = "lb-fft",
},
["lbf.ft"] = {
target = "lbfft",
},
["lbf·ft"] = {
target = "lbfft",
},
["lb·ft"] = {
target = "lb.ft",
},
["mkg-f"] = {
target = "m.kg-f",
},
["mkgf"] = {
target = "m.kgf",
},
["N.m"] = {
target = "Nm",
},
["N·m"] = {
target = "Nm",
},
["ton-mile"] = {
symbol = "ton-mile",
usename = 1,
utype = "transportation",
scale = 1.4599723182105602,
default = "tkm",
},
["tkm"] = {
name1 = "tonne-kilometre",
name1_us = "tonne-kilometer",
symbol = "tkm",
utype = "transportation",
scale = 1,
default = "ton-mile",
},
["-12USoz(mL)serve"] = {
name1_us = "12 U.S. fl oz (355 mL) serving",
symbol = "12 US fl oz (355 mL) serving",
sym_us = "12 U.S. fl oz (355 mL) serving",
utype = "volume",
scale = 0.00035488235475000004,
default = "mL",
link = "Beverage can#Standard sizes",
},
["-12USoz(ml)serve"] = {
name1_us = "12 U.S. fl oz (355 ml) serving",
symbol = "12 US fl oz (355 ml) serving",
sym_us = "12 U.S. fl oz (355 ml) serving",
utype = "volume",
scale = 0.00035488235475000004,
default = "ml",
link = "Beverage can#Standard sizes",
},
["-12USozserve"] = {
name1_us = "12 U.S. fl oz serving",
symbol = "12 US fl oz serving",
sym_us = "12 U.S. fl oz serving",
utype = "volume",
scale = 0.00035488235475000004,
default = "mL",
link = "Beverage can#Standard sizes",
},
["acre-foot"] = {
name1 = "acre-foot",
name2 = "acre-foot",
symbol = "acre⋅ft",
utype = "volume",
scale = 1233.48183754752,
default = "m3",
},
["acre-ft"] = {
name1 = "acre-foot",
name2 = "acre-feet",
symbol = "acre⋅ft",
utype = "volume",
scale = 1233.48183754752,
default = "m3",
},
["AUtbsp"] = {
name1 = "Australian tablespoon",
symbol = "AU tbsp",
utype = "volume",
scale = 0.000020,
default = "ml",
},
["Bcuft"] = {
name1 = "billion cubic foot",
name2 = "billion cubic feet",
symbol = "billion cu ft",
utype = "volume",
scale = 28316846.592,
default = "Gl",
link = "Cubic foot",
},
["bdft"] = {
name1 = "board foot",
name2 = "board feet",
symbol = "bd ft",
utype = "volume",
scale = 0.0023597372167,
default = "m3",
},
["board feet"] = {
name2 = "board feet",
symbol = "board foot",
usename = 1,
utype = "volume",
scale = 0.0023597372167,
default = "m3",
},
["board foot"] = {
name2 = "board foot",
symbol = "board foot",
usename = 1,
utype = "volume",
scale = 0.0023597372167,
default = "m3",
},
["cc"] = {
name1 = "cubic centimetre",
name1_us = "cubic centimeter",
symbol = "cc",
utype = "volume",
scale = 0.000001,
default = "cuin",
},
["CID"] = {
name1 = "cubic inch",
name2 = "cubic inches",
symbol = "cu in",
utype = "volume",
scale = 0.000016387064,
default = "cc",
link = "Cubic inch#Engine displacement",
},
["cord"] = {
symbol = "cord",
utype = "volume",
scale = 3.624556363776,
default = "m3",
link = "Cord (unit)",
},
["cufoot"] = {
name1 = "cubic foot",
name2 = "cubic foot",
symbol = "cu ft",
utype = "volume",
scale = 0.028316846592,
default = "m3",
},
["cuft"] = {
name1 = "cubic foot",
name2 = "cubic feet",
symbol = "cu ft",
utype = "volume",
scale = 0.028316846592,
default = "m3",
},
["cuin"] = {
name1 = "cubic inch",
name2 = "cubic inches",
symbol = "cu in",
utype = "volume",
scale = 0.000016387064,
default = "cm3",
},
["cumi"] = {
name1 = "cubic mile",
symbol = "cu mi",
utype = "volume",
scale = 4168181825.440579584,
default = "km3",
},
["cuyd"] = {
name1 = "cubic yard",
symbol = "cu yd",
utype = "volume",
scale = 0.764554857984,
default = "m3",
},
["firkin"] = {
symbol = "firkin",
usename = 1,
utype = "volume",
scale = 0.04091481,
default = "L impgal USgal",
link = "Firkin (unit)",
},
["foot3"] = {
target = "cufoot",
},
["Goilbbl"] = {
name1 = "billion barrels",
name2 = "billion barrels",
symbol = "Gbbl",
utype = "volume",
scale = 158987294.928,
default = "v * 1.58987294928 < 10 ! e6 ! e9 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["gr water"] = {
name1 = "grains water",
name2 = "grains water",
symbol = "gr H<sub>2</sub>O",
utype = "volume",
scale = 0.00000006479891,
default = "cm3",
link = "Grain (unit)",
},
["grt"] = {
name1 = "gross register ton",
symbol = "grt",
utype = "volume",
scale = 2.8316846592,
default = "m3",
link = "Gross register tonnage",
},
["impbbl"] = {
name1 = "imperial barrel",
symbol = "imp bbl",
utype = "volume",
scale = 0.16365924,
default = "L impgal USgal",
link = "Barrel (unit)",
},
["impbsh"] = {
name1 = "imperial bushel",
symbol = "imp bsh",
utype = "volume",
scale = 0.03636872,
default = "L impgal USdrygal",
},
["impbu"] = {
name1 = "imperial bushel",
symbol = "imp bu",
utype = "volume",
scale = 0.03636872,
default = "m3",
},
["impgal"] = {
name1 = "imperial gallon",
symbol = "imp gal",
utype = "volume",
scale = 0.00454609,
default = "L USgal",
},
["impgi"] = {
name1 = "gill",
symbol = "gi",
utype = "volume",
scale = 0.0001420653125,
default = "ml USoz",
link = "Gill (unit)",
},
["impkenning"] = {
name1 = "imperial kenning",
symbol = "kenning",
utype = "volume",
scale = 0.01818436,
default = "L USdrygal",
link = "Kenning (unit)",
},
["impoz"] = {
name1 = "imperial fluid ounce",
symbol = "imp fl oz",
utype = "volume",
scale = 0.0000284130625,
default = "ml USoz",
},
["imppk"] = {
name1 = "imperial peck",
symbol = "pk",
utype = "volume",
scale = 0.00909218,
default = "L USdrygal",
link = "Peck",
},
["imppt"] = {
name1 = "imperial pint",
symbol = "imp pt",
utype = "volume",
scale = 0.00056826125,
default = "L",
},
["impqt"] = {
name1 = "imperial quart",
symbol = "imp qt",
utype = "volume",
scale = 0.0011365225,
default = "ml USoz",
customary= 3,
},
["kilderkin"] = {
symbol = "kilderkin",
usename = 1,
utype = "volume",
scale = 0.08182962,
default = "L impgal USgal",
},
["koilbbl"] = {
name1 = "thousand barrels",
name2 = "thousand barrels",
symbol = "kbbl",
utype = "volume",
scale = 158.987294928,
default = "v * 1.58987294928 < 10 ! ! e3 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["L"] = {
_name1 = "litre",
_name1_us= "liter",
_symbol = "L",
utype = "volume",
scale = 0.001,
prefixes = 1,
default = "impgal USgal",
link = "Litre",
},
["l"] = {
_name1 = "litre",
_name1_us= "liter",
_symbol = "l",
utype = "volume",
scale = 0.001,
prefixes = 1,
default = "impgal USgal",
link = "Litre",
},
["ll"] = {
name1 = "litre",
name1_us = "liter",
symbol = "l",
utype = "volume",
scale = 0.001,
default = "impgal USgal",
},
["m3"] = {
_name1 = "cubic metre",
_name1_us= "cubic meter",
_symbol = "m<sup>3</sup>",
prefix_position= 7,
utype = "volume",
scale = 1,
prefixes = 3,
default = "cuft",
link = "Cubic metre",
},
["Mbbl"] = {
name1 = "thousand barrels",
name2 = "thousand barrels",
symbol = "Mbbl",
utype = "volume",
scale = 158.987294928,
default = "v * 1.58987294928 < 10 ! e3 ! ! m3",
link = "Barrel (unit)#Oil barrel",
},
["MMoilbbl"] = {
name1 = "million barrels",
name2 = "million barrels",
symbol = "MMbbl",
utype = "volume",
scale = 158987.294928,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["Moilbbl"] = {
name1 = "million barrels",
name2 = "million barrels",
symbol = "Mbbl",
utype = "volume",
scale = 158987.294928,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["MTON"] = {
name1 = "measurement ton",
symbol = "MTON",
utype = "volume",
scale = 1.13267386368,
default = "m3",
},
["MUSgal"] = {
name1 = "million US gallons",
name1_us = "million U.S. gallons",
name2 = "million US gallons",
name2_us = "million U.S. gallons",
symbol = "million US gal",
sym_us = "million U.S. gal",
utype = "volume",
scale = 3785.411784,
default = "Ml",
link = "US gallon",
},
["oilbbl"] = {
name1 = "barrel",
symbol = "bbl",
utype = "volume",
scale = 0.158987294928,
default = "m3",
link = "Barrel (unit)#Oil barrel",
},
["stere"] = {
symbol = "stere",
usename = 1,
utype = "volume",
scale = 1,
default = "cuft",
},
["Toilbbl"] = {
name1 = "trillion barrels",
name2 = "trillion barrels",
symbol = "Tbbl",
utype = "volume",
scale = 158987294928,
default = "v * 1.58987294928 < 10 ! e9 ! e12 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["USbbl"] = {
name1 = "US barrel",
name1_us = "U.S. barrel",
symbol = "US bbl",
sym_us = "U.S. bbl",
utype = "volume",
scale = 0.119240471196,
default = "L USgal impgal",
link = "Barrel (unit)",
},
["USbeerbbl"] = {
name1 = "US beer barrel",
name1_us = "U.S. beer barrel",
symbol = "US bbl",
sym_us = "U.S. bbl",
utype = "volume",
scale = 0.117347765304,
default = "L USgal impgal",
link = "Barrel (unit)",
},
["USbsh"] = {
name1 = "US bushel",
name1_us = "U.S. bushel",
symbol = "US bsh",
sym_us = "U.S. bsh",
utype = "volume",
scale = 0.03523907016688,
default = "L USdrygal impgal",
link = "Bushel",
},
["USbu"] = {
name1 = "US bushel",
name1_us = "U.S. bushel",
symbol = "US bu",
sym_us = "U.S. bu",
utype = "volume",
scale = 0.03523907016688,
default = "L USdrygal impgal",
link = "Bushel",
},
["USdrybbl"] = {
name1 = "US dry barrel",
name1_us = "U.S. dry barrel",
symbol = "US dry bbl",
sym_us = "U.S. dry bbl",
utype = "volume",
scale = 0.11562819898508,
default = "m3",
link = "Barrel (unit)",
},
["USdrygal"] = {
name1 = "US dry gallon",
name1_us = "U.S. dry gallon",
symbol = "US dry gal",
sym_us = "U.S. dry gal",
utype = "volume",
scale = 0.00440488377086,
default = "L",
link = "Gallon",
},
["USdrypt"] = {
name1 = "US dry pint",
name1_us = "U.S. dry pint",
symbol = "US dry pt",
sym_us = "U.S. dry pt",
utype = "volume",
scale = 0.0005506104713575,
default = "ml",
link = "Pint",
},
["USdryqt"] = {
name1 = "US dry quart",
name1_us = "U.S. dry quart",
symbol = "US dry qt",
sym_us = "U.S. dry qt",
utype = "volume",
scale = 0.001101220942715,
default = "ml",
link = "Quart",
},
["USflgal"] = {
name1 = "US gallon",
name1_us = "U.S. gallon",
symbol = "US fl gal",
sym_us = "U.S. fl gal",
utype = "volume",
scale = 0.003785411784,
default = "L impgal",
link = "Gallon",
},
["USgal"] = {
name1 = "US gallon",
name1_us = "U.S. gallon",
symbol = "US gal",
sym_us = "U.S. gal",
utype = "volume",
scale = 0.003785411784,
default = "L impgal",
},
["USgi"] = {
name1 = "gill",
symbol = "gi",
utype = "volume",
scale = 0.0001182941183,
default = "ml impoz",
link = "Gill (unit)",
},
["USkenning"] = {
name1 = "US kenning",
name1_us = "U.S. kenning",
symbol = "US kenning",
sym_us = "U.S. kenning",
utype = "volume",
scale = 0.01761953508344,
default = "L impgal",
link = "Kenning (unit)",
},
["USmin"] = {
name1 = "US minim",
name1_us = "U.S. minim",
symbol = "US min",
sym_us = "U.S. min",
utype = "volume",
scale = 0.000000061611519921875,
default = "ml",
link = "Minim (unit)",
},
["USoz"] = {
name1 = "US fluid ounce",
name1_us = "U.S. fluid ounce",
symbol = "US fl oz",
sym_us = "U.S. fl oz",
utype = "volume",
scale = 0.0000295735295625,
default = "ml",
},
["USpk"] = {
name1 = "US peck",
name1_us = "U.S. peck",
symbol = "US pk",
sym_us = "U.S. pk",
utype = "volume",
scale = 0.00880976754172,
default = "L impgal",
link = "Peck",
},
["USpt"] = {
name1 = "US pint",
name1_us = "U.S. pint",
symbol = "US pt",
sym_us = "U.S. pt",
utype = "volume",
scale = 0.000473176473,
default = "L imppt",
link = "Pint",
},
["USqt"] = {
name1 = "US quart",
name1_us = "U.S. quart",
symbol = "US qt",
sym_us = "U.S. qt",
utype = "volume",
scale = 0.000946352946,
default = "ml",
link = "Quart",
customary= 1,
},
["USquart"] = {
name1 = "US quart",
name1_us = "U.S. quart",
symbol = "US qt",
sym_us = "U.S. qt",
utype = "volume",
scale = 0.000946352946,
default = "ml impoz",
link = "Quart",
},
["UStbsp"] = {
name1 = "US tablespoon",
name1_us = "U.S. tablespoon",
symbol = "US tbsp",
sym_us = "U.S. tbsp",
utype = "volume",
scale = 1.4786764781250001e-5,
default = "ml",
},
["winecase"] = {
symbol = "case",
usename = 1,
utype = "volume",
scale = 0.009,
default = "L",
link = "Case (goods)",
},
["*U.S.drygal"] = {
target = "USdrygal",
sp_us = true,
customary= 2,
},
["*U.S.gal"] = {
target = "USgal",
sp_us = true,
customary= 2,
},
["+USdrygal"] = {
target = "USdrygal",
customary= 1,
},
["+usfloz"] = {
target = "USoz",
link = "Fluid ounce",
customary= 1,
},
["+USgal"] = {
target = "USgal",
customary= 1,
},
["+USoz"] = {
target = "USoz",
customary= 1,
},
["@impgal"] = {
target = "impgal",
link = "Gallon",
customary= 3,
},
["acre feet"] = {
target = "acre-ft",
},
["acre foot"] = {
target = "acre-foot",
},
["acre ft"] = {
target = "acre-ft",
},
["acre-feet"] = {
target = "acre-ft",
},
["acre.foot"] = {
target = "acre-foot",
},
["acre.ft"] = {
target = "acre-ft",
},
["acre·ft"] = {
target = "acre-ft",
},
["bushels"] = {
target = "USbsh",
},
["cid"] = {
target = "CID",
},
["ft3"] = {
target = "cuft",
},
["gal"] = {
target = "USgal",
},
["gallon"] = {
shouldbe = "Use %{USgal%} for US gallons or %{impgal%} for imperial gallons (not %{gallon%})",
},
["gallons"] = {
shouldbe = "Use %{USgal%} for US gallons or %{impgal%} for imperial gallons (not %{gallons%})",
},
["Gcuft"] = {
target = "e9cuft",
},
["impfloz"] = {
target = "impoz",
},
["Impgal"] = {
target = "impgal",
},
["in3"] = {
target = "cuin",
symbol = "in<sup>3</sup>",
},
["hm³"] = {
target = "hm3",
},
["kcuft"] = {
target = "e3cuft",
},
["kcum"] = {
target = "e3m3",
},
["km³"] = {
target = "km3",
},
["liter"] = {
target = "L",
sp_us = true,
},
["liters"] = {
target = "L",
sp_us = true,
},
["litre"] = {
target = "L",
},
["litres"] = {
target = "L",
},
["Mcuft"] = {
target = "e6cuft",
},
["Mcum"] = {
target = "e6m3",
},
["Mft3"] = {
target = "e6cuft",
},
["mi3"] = {
target = "cumi",
},
["m³"] = {
target = "m3",
},
["Pcuft"] = {
target = "e15cuft",
},
["pt"] = {
shouldbe = "Use %{USpt%} for US pints or %{imppt%} for imperial pints (not %{pt%})",
},
["qt"] = {
shouldbe = "Use %{USqt%} for US quarts or %{impqt%} for imperial quarts (not %{qt%})",
},
["Tcuft"] = {
target = "e12cuft",
},
["Tft3"] = {
target = "e12cuft",
},
["U.S.bbl"] = {
target = "USbbl",
sp_us = true,
default = "L U.S.gal impgal",
},
["U.S.beerbbl"] = {
target = "USbeerbbl",
sp_us = true,
default = "L U.S.gal impgal",
},
["U.S.bsh"] = {
target = "USbsh",
sp_us = true,
default = "L U.S.drygal impgal",
},
["U.S.bu"] = {
target = "USbu",
sp_us = true,
default = "L U.S.drygal impgal",
},
["U.S.drybbl"] = {
target = "USdrybbl",
sp_us = true,
},
["U.S.drygal"] = {
target = "USdrygal",
sp_us = true,
},
["U.S.drypt"] = {
target = "USdrypt",
sp_us = true,
},
["U.S.dryqt"] = {
target = "USdryqt",
sp_us = true,
},
["U.S.flgal"] = {
target = "USflgal",
sp_us = true,
},
["U.S.floz"] = {
target = "USoz",
sp_us = true,
},
["U.S.gal"] = {
target = "USgal",
sp_us = true,
link = "U.S. gallon",
},
["u.s.gal"] = {
target = "USgal",
sp_us = true,
link = "U.S. gallon",
},
["U.S.gi"] = {
target = "USgi",
sp_us = true,
},
["U.S.kenning"] = {
target = "USkenning",
sp_us = true,
},
["U.S.oz"] = {
target = "USoz",
sp_us = true,
},
["U.S.pk"] = {
target = "USpk",
sp_us = true,
},
["U.S.pt"] = {
target = "USpt",
sp_us = true,
},
["U.S.qt"] = {
target = "USqt",
sp_us = true,
default = "L impqt",
customary= 2,
},
["usbbl"] = {
target = "USbbl",
},
["usbeerbbl"] = {
target = "USbeerbbl",
},
["usbsh"] = {
target = "USbsh",
},
["usbu"] = {
target = "USbu",
},
["usdrybbl"] = {
target = "USdrybbl",
},
["usdrygal"] = {
target = "USdrygal",
},
["usdrypt"] = {
target = "USdrypt",
},
["usdryqt"] = {
target = "USdryqt",
},
["USfloz"] = {
target = "USoz",
},
["usfloz"] = {
target = "USoz",
},
["USGAL"] = {
target = "USgal",
},
["usgal"] = {
target = "USgal",
},
["usgi"] = {
target = "USgi",
},
["uskenning"] = {
target = "USkenning",
},
["usoz"] = {
target = "USoz",
},
["uspk"] = {
target = "USpk",
},
["uspt"] = {
target = "USpt",
},
["usqt"] = {
target = "USqt",
},
["yd3"] = {
target = "cuyd",
},
["cuft/sqmi"] = {
per = { "cuft", "sqmi" },
utype = "volume per unit area",
default = "m3/km2",
},
["m3/ha"] = {
name1 = "cubic metre per hectare",
name1_us = "cubic meter per hectare",
name2 = "cubic metres per hectare",
name2_us = "cubic meters per hectare",
symbol = "m<sup>3</sup>/ha",
utype = "volume per unit area",
scale = 0.0001,
default = "USbu/acre",
link = "Hectare",
},
["m3/km2"] = {
per = { "m3", "km2" },
utype = "volume per unit area",
default = "cuft/sqmi",
},
["U.S.gal/acre"] = {
per = { "U.S.gal", "acre" },
utype = "volume per unit area",
default = "m3/km2",
},
["USbu/acre"] = {
name2 = "US bushels per acre",
symbol = "US bushel per acre",
usename = 1,
utype = "volume per unit area",
scale = 8.7077638761350888e-6,
default = "m3/ha",
link = "Bushel",
},
["USgal/acre"] = {
per = { "USgal", "acre" },
utype = "volume per unit area",
default = "m3/km2",
},
["cuyd/mi"] = {
per = { "cuyd", "mi" },
utype = "volume per unit length",
default = "m3/km",
},
["m3/km"] = {
per = { "m3", "km" },
utype = "volume per unit length",
default = "cuyd/mi",
},
["mich"] = {
combination= { "ch", "mi" },
multiple = { 80 },
utype = "length",
},
["michlk"] = {
combination= { "chlk", "mi" },
multiple = { 80 },
utype = "length",
},
["michainlk"] = {
combination= { "chainlk", "mi" },
multiple = { 80 },
utype = "length",
},
["miyd"] = {
combination= { "yd", "mi" },
multiple = { 1760 },
utype = "length",
},
["miydftin"] = {
combination= { "in", "ft", "yd", "mi" },
multiple = { 12, 3, 1760 },
utype = "length",
},
["mift"] = {
combination= { "ft", "mi" },
multiple = { 5280 },
utype = "length",
},
["ydftin"] = {
combination= { "in", "ft", "yd" },
multiple = { 12, 3 },
utype = "length",
},
["ydft"] = {
combination= { "ft", "yd" },
multiple = { 3 },
utype = "length",
},
["ftin"] = {
combination= { "in", "ft" },
multiple = { 12 },
utype = "length",
},
["footin"] = {
combination= { "in", "foot" },
multiple = { 12 },
utype = "length",
},
["handin"] = {
combination= { "in", "hand" },
multiple = { 4 },
utype = "length",
},
["lboz"] = {
combination= { "oz", "lb" },
multiple = { 16 },
utype = "mass",
},
["stlb"] = {
combination= { "lb", "st" },
multiple = { 14 },
utype = "mass",
},
["stlboz"] = {
combination= { "oz", "lb", "st" },
multiple = { 16, 14 },
utype = "mass",
},
["st and lb"] = {
combination= { "lb", "st" },
multiple = { 14 },
utype = "mass",
},
["GN LTf"] = {
combination= { "GN", "-LTf" },
utype = "force",
},
["GN LTf STf"] = {
combination= { "GN", "-LTf", "-STf" },
utype = "force",
},
["GN STf"] = {
combination= { "GN", "-STf" },
utype = "force",
},
["GN STf LTf"] = {
combination= { "GN", "-STf", "-LTf" },
utype = "force",
},
["kN LTf"] = {
combination= { "kN", "-LTf" },
utype = "force",
},
["kN LTf STf"] = {
combination= { "kN", "-LTf", "-STf" },
utype = "force",
},
["kN STf"] = {
combination= { "kN", "-STf" },
utype = "force",
},
["kN STf LTf"] = {
combination= { "kN", "-STf", "-LTf" },
utype = "force",
},
["LTf STf"] = {
combination= { "-LTf", "-STf" },
utype = "force",
},
["MN LTf"] = {
combination= { "MN", "-LTf" },
utype = "force",
},
["MN LTf STf"] = {
combination= { "MN", "-LTf", "-STf" },
utype = "force",
},
["MN STf"] = {
combination= { "MN", "-STf" },
utype = "force",
},
["MN STf LTf"] = {
combination= { "MN", "-STf", "-LTf" },
utype = "force",
},
["STf LTf"] = {
combination= { "-STf", "-LTf" },
utype = "force",
},
["L/100 km mpgimp"] = {
combination= { "L/100 km", "mpgimp" },
utype = "fuel efficiency",
},
["l/100 km mpgimp"] = {
combination= { "l/100 km", "mpgimp" },
utype = "fuel efficiency",
},
["L/100 km mpgUS"] = {
combination= { "L/100 km", "mpgus" },
utype = "fuel efficiency",
},
["L/100 km mpgus"] = {
combination= { "L/100 km", "mpgus" },
utype = "fuel efficiency",
},
["l/100 km mpgus"] = {
combination= { "l/100 km", "mpgus" },
utype = "fuel efficiency",
},
["mpgimp L/100 km"] = {
combination= { "mpgimp", "L/100 km" },
utype = "fuel efficiency",
},
["LT ST t"] = {
combination= { "lt", "-ST", "t" },
utype = "mass",
},
["LT t ST"] = {
combination= { "lt", "t", "-ST" },
utype = "mass",
},
["ST LT t"] = {
combination= { "-ST", "lt", "t" },
utype = "mass",
},
["ST t LT"] = {
combination= { "-ST", "t", "lt" },
utype = "mass",
},
["t LT ST"] = {
combination= { "t", "lt", "-ST" },
utype = "mass",
},
["ton"] = {
combination= { "LT", "ST" },
utype = "mass",
},
["kPa kg/cm2"] = {
combination= { "kPa", "kgf/cm2" },
utype = "pressure",
},
["kPa lb/in2"] = {
combination= { "kPa", "-lb/in2" },
utype = "pressure",
},
["floz"] = {
combination= { "impoz", "USoz" },
utype = "volume",
},
}
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local default_exceptions = {
-- Prefixed units with a default different from that of the base unit.
-- Each key item is a prefixed symbol (unitcode for engineering notation).
["cm<sup>2</sup>"] = "sqin",
["dm<sup>2</sup>"] = "sqin",
["e3acre"] = "km2",
["e3m2"] = "e6sqft",
["e6acre"] = "km2",
["e6ha"] = "e6acre",
["e6km2"] = "e6sqmi",
["e6m2"] = "e6sqft",
["e6sqft"] = "v * 9.290304 < 100 ! e3 ! e6 ! m2",
["e6sqmi"] = "e6km2",
["hm<sup>2</sup>"] = "acre",
["km<sup>2</sup>"] = "sqmi",
["mm<sup>2</sup>"] = "sqin",
["aJ"] = "eV",
["e3BTU"] = "MJ",
["e6BTU"] = "GJ",
["EJ"] = "kWh",
["fJ"] = "keV",
["GJ"] = "kWh",
["MJ"] = "kWh",
["PJ"] = "kWh",
["pJ"] = "MeV",
["TJ"] = "kWh",
["YJ"] = "kWh",
["yJ"] = "μeV",
["ZJ"] = "kWh",
["zJ"] = "meV",
["e12cuft/a"] = "v * 2.8316846592 < 100 ! e9 ! e12 ! m3/a",
["e12cuft/d"] = "v * 2.8316846592 < 100 ! e9 ! e12 ! m3/d",
["e12m3/a"] = "Tcuft/a",
["e12m3/d"] = "Tcuft/d",
["e3cuft/a"] = "v * 2.8316846592 < 100 ! ! e3 ! m3/a",
["e3cuft/d"] = "v * 2.8316846592 < 100 ! ! e3 ! m3/d",
["e3cuft/s"] = "v * 2.8316846592 < 100 ! ! e3 ! m3/s",
["e3m3/a"] = "v < 28.316846592 ! k ! M ! cuft/a",
["e3m3/d"] = "v < 28.316846592 ! k ! M ! cuft/d",
["e3m3/s"] = "v < 28.316846592 ! k ! M ! cuft/s",
["e3USgal/a"] = "v * 3.785411784 < 1000 ! ! e3 ! m3/a",
["e6cuft/a"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3/a",
["e6cuft/d"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3/d",
["e6cuft/s"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3/s",
["e6m3/a"] = "v < 28.316846592 ! M ! G ! cuft/a",
["e6m3/d"] = "v < 28.316846592 ! M ! G ! cuft/d",
["e6m3/s"] = "v < 28.316846592 ! e6 ! e9 ! cuft/s",
["e6USgal/a"] = "v * 3.785411784 < 1000 ! e3 ! e6 ! m3/a",
["e9cuft/a"] = "m3/a",
["e9cuft/d"] = "v * 2.8316846592 < 100 ! e6 ! e9 ! m3/d",
["e9m3/a"] = "v < 28.316846592 ! G ! T ! cuft/a",
["e9m3/d"] = "v < 28.316846592 ! G ! T ! cuft/d",
["e9m3/s"] = "v < 28.316846592 ! e9 ! e12 ! cuft/s",
["e9USgal/a"] = "v * 3.785411784 < 1000 ! e6 ! e9 ! m3/a",
["e9USgal/s"] = "v * 3.785411784 < 1000 ! e6 ! e9 ! m3/s",
["nN"] = "gr-f",
["μN"] = "gr-f",
["mN"] = "oz-f",
["am"] = "in",
["cm"] = "in",
["dam"] = "ft",
["dm"] = "in",
["e12km"] = "e12mi",
["e12mi"] = "e12km",
["e3AU"] = "ly",
["e3km"] = "e3mi",
["e3mi"] = "e3km",
["e6km"] = "e6mi",
["e6mi"] = "e6km",
["e9km"] = "AU",
["e9mi"] = "e9km",
["Em"] = "mi",
["fm"] = "in",
["Gm"] = "mi",
["hm"] = "ft",
["km"] = "mi",
["mm"] = "in",
["Mm"] = "mi",
["nm"] = "in",
["Pm"] = "mi",
["pm"] = "in",
["Tm"] = "mi",
["Ym"] = "mi",
["ym"] = "in",
["Zm"] = "mi",
["zm"] = "in",
["μm"] = "in",
["e12lb"] = "v * 4.5359237 < 10 ! Mt ! Gt",
["e3lb"] = "v * 4.5359237 < 10 ! kg ! t",
["e3ozt"] = "v * 0.311034768 < 10 ! kg ! t",
["e3t"] = "LT ST",
["e6carat"] = "t",
["e6lb"] = "v * 4.5359237 < 10 ! t ! kilotonne",
["e6ozt"] = "lb kg",
["e6ST"] = "Mt",
["e6t"] = "LT ST",
["e9lb"] = "v * 4.5359237 < 10 ! kilotonne ! Mt",
["e9t"] = "LT ST",
["Gg"] = "lb",
["kg"] = "lb",
["mg"] = "gr",
["Mg"] = "LT ST",
["ng"] = "gr",
["μg"] = "gr",
["mBq"] = "fCi",
["kBq"] = "nCi",
["MBq"] = "μCi",
["GBq"] = "mCi",
["TBq"] = "Ci",
["PBq"] = "kCi",
["EBq"] = "kCi",
["fCi"] = "mBq",
["pCi"] = "Bq",
["nCi"] = "Bq",
["μCi"] = "kBq",
["mCi"] = "MBq",
["kCi"] = "TBq",
["MCi"] = "PBq",
["ns"] = "μs",
["μs"] = "ms",
["ms"] = "s",
["ks"] = "h",
["Ms"] = "week",
["Gs"] = "decade",
["Ts"] = "millennium",
["Ps"] = "million year",
["Es"] = "thousand million year",
["MK"] = "keVT",
["cL"] = "impoz usoz",
["cl"] = "impoz usoz",
["cm<sup>3</sup>"] = "cuin",
["dL"] = "impoz usoz",
["dl"] = "impoz usoz",
["mm<sup>3</sup>"] = "cuin",
["dm<sup>3</sup>"] = "cuin",
["e12cuft"] = "v * 2.8316846592 < 100 ! e9 ! e12 ! m3",
["e12impgal"] = "v * 4.54609 < 1000 ! T ! P ! l",
["e12m3"] = "v < 28.316846592 ! T ! P ! cuft",
["e12U.S.gal"] = "v * 3.785411784 < 1000 ! T ! P ! l",
["e12USgal"] = "v * 3.785411784 < 1000 ! T ! P ! l",
["e15cuft"] = "v * 2.8316846592 < 100 ! e12 ! e15 ! m3",
["e15m3"] = "Pcuft",
["e3bdft"] = "v * 0.23597372167 < 100 ! e3 ! e6 ! m3",
["e3cuft"] = "v * 2.8316846592 < 100 ! ! e3 ! m3",
["e3impgal"] = "v * 4.54609 < 1000 ! k ! M ! l",
["e3m3"] = "v < 28.316846592 ! k ! M ! cuft",
["e3U.S.gal"] = "v * 3.785411784 < 1000 ! k ! M ! l",
["e3USgal"] = "v * 3.785411784 < 1000 ! k ! M ! l",
["e6bdft"] = "v * 0.23597372167 < 100 ! e3 ! e6 ! m3",
["e6cuft"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3",
["e6cuyd"] = "v * 7.64554857984 < 10 ! e3 ! e6 ! m3",
["e6impgal"] = "v * 4.54609 < 1000 ! M ! G ! l",
["e6L"] = "USgal",
["e6m3"] = "v < 28.316846592 ! M ! G ! cuft",
["e6U.S.gal"] = "v * 3.785411784 < 1000 ! M ! G ! l",
["e6USgal"] = "v * 3.785411784 < 1000 ! M ! G ! l",
["e9bdft"] = "v * 0.23597372167 < 100 ! e6 ! e9 ! m3",
["e9cuft"] = "v * 2.8316846592 < 100 ! e6 ! e9 ! m3",
["e9impgal"] = "v * 4.54609 < 1000 ! G ! T ! l",
["e9m3"] = "v < 28.316846592 ! G ! T ! cuft",
["e9U.S.gal"] = "v * 3.785411784 < 1000 ! G ! T ! l",
["e9USgal"] = "v * 3.785411784 < 1000 ! G ! T ! l",
["GL"] = "cuft",
["Gl"] = "cuft",
["kL"] = "cuft",
["kl"] = "cuft",
["km<sup>3</sup>"] = "cumi",
["mL"] = "impoz usoz",
["ml"] = "impoz usoz",
["Ml"] = "v < 28.316846592 ! e3 ! e6 ! cuft",
["ML"] = "v < 28.316846592 ! e3 ! e6 ! cuft",
["TL"] = "cumi",
["Tl"] = "cumi",
["μL"] = "cuin",
["μl"] = "cuin",
}
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local link_exceptions = {
-- Prefixed units with a linked article different from that of the base unit.
-- Each key item is a prefixed symbol (not unitcode).
["mm<sup>2</sup>"] = "Square millimetre",
["cm<sup>2</sup>"] = "Square centimetre",
["dm<sup>2</sup>"] = "Square decimetre",
["km<sup>2</sup>"] = "Square kilometre",
["kJ"] = "Kilojoule",
["MJ"] = "Megajoule",
["GJ"] = "Gigajoule",
["TJ"] = "Terajoule",
["fm"] = "Femtometre",
["pm"] = "Picometre",
["nm"] = "Nanometre",
["μm"] = "Micrometre",
["mm"] = "Millimetre",
["cm"] = "Centimetre",
["dm"] = "Decimetre",
["dam"] = "Decametre",
["hm"] = "Hectometre",
["km"] = "Kilometre",
["Mm"] = "Megametre",
["Gm"] = "Gigametre",
["Tm"] = "Terametre",
["Pm"] = "Petametre",
["Em"] = "Exametre",
["Zm"] = "Zettametre",
["Ym"] = "Yottametre",
["μg"] = "Microgram",
["mg"] = "Milligram",
["kg"] = "Kilogram",
["Mg"] = "Tonne",
["yW"] = "Yoctowatt",
["zW"] = "Zeptowatt",
["aW"] = "Attowatt",
["fW"] = "Femtowatt",
["pW"] = "Picowatt",
["nW"] = "Nanowatt",
["μW"] = "Microwatt",
["mW"] = "Milliwatt",
["kW"] = "Kilowatt",
["MW"] = "Megawatt",
["GW"] = "Gigawatt",
["TW"] = "Terawatt",
["PW"] = "Petawatt",
["EW"] = "Exawatt",
["ZW"] = "Zettawatt",
["YW"] = "Yottawatt",
["as"] = "Attosecond",
["fs"] = "Femtosecond",
["ps"] = "Picosecond",
["ns"] = "Nanosecond",
["μs"] = "Microsecond",
["ms"] = "Millisecond",
["ks"] = "Kilosecond",
["Ms"] = "Megasecond",
["Gs"] = "Gigasecond",
["Ts"] = "Terasecond",
["Ps"] = "Petasecond",
["Es"] = "Exasecond",
["Zs"] = "Zettasecond",
["Ys"] = "Yottasecond",
["mm<sup>3</sup>"] = "Cubic millimetre",
["cm<sup>3</sup>"] = "Cubic centimetre",
["dm<sup>3</sup>"] = "Cubic decimetre",
["dam<sup>3</sup>"] = "Cubic decametre",
["km<sup>3</sup>"] = "Cubic kilometre",
["μL"] = "Microlitre",
["μl"] = "Microlitre",
["mL"] = "Millilitre",
["ml"] = "Millilitre",
["cL"] = "Centilitre",
["cl"] = "Centilitre",
["dL"] = "Decilitre",
["dl"] = "Decilitre",
["daL"] = "Decalitre",
["dal"] = "Decalitre",
["hL"] = "Hectolitre",
["hl"] = "Hectolitre",
["kL"] = "Kilolitre",
["kl"] = "Kilolitre",
["ML"] = "Megalitre",
["Ml"] = "Megalitre",
["GL"] = "Gigalitre",
["Gl"] = "Gigalitre",
["TL"] = "Teralitre",
["Tl"] = "Teralitre",
["PL"] = "Petalitre",
["Pl"] = "Petalitre",
}
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local per_unit_fixups = {
-- Automatically created per units of form "x/y" may have their unit type
-- changed, for example, "length/time" is changed to "speed".
-- Other adjustments can also be specified.
["/area"] = "per unit area",
["/volume"] = "per unit volume",
["area/area"] = "area per unit area",
["energy/length"] = "energy per unit length",
["energy/mass"] = "energy per unit mass",
["energy/time"] = { utype = "power", link = "Power (physics)" },
["energy/volume"] = "energy per unit volume",
["force/area"] = { utype = "pressure", link = "Pressure" },
["length/length"] = { utype = "gradient", link = "Grade (slope)" },
["length/time"] = { utype = "speed", link = "Speed" },
["length/time/time"] = { utype = "acceleration", link = "Acceleration" },
["mass/area"] = { utype = "pressure", multiplier = 9.80665 },
["mass/length"] = "linear density",
["mass/mass"] = "concentration",
["mass/power"] = "mass per unit power",
["mass/time"] = "mass per unit time",
["mass/volume"] = { utype = "density", link = "Density" },
["power/mass"] = "power per unit mass",
["power/volume"] = { link = "Power density" },
["pressure/length"] = "fracture gradient",
["speed/time"] = { utype = "acceleration", link = "Acceleration" },
["volume/area"] = "volume per unit area",
["volume/length"] = "volume per unit length",
["volume/time"] = "flow",
}
return {
all_units = all_units,
default_exceptions = default_exceptions,
link_exceptions = link_exceptions,
per_unit_fixups = per_unit_fixups,
}
69cd04fba2962c152d0008b00cb8b7df57549e07
Module:Convert/text
828
722
1107
2024-10-26T23:10:17Z
wikipedia>Johnuniq
0
update from sandbox per [[Template talk:Convert#Module version 30]]
Scribunto
text/plain
-- Text used by Module:Convert for enwiki.
-- This is a separate module to simplify translation for use on another wiki.
-- See [[:en:Template:Convert/Transwiki guide]] if copying to another wiki.
-- Some units accept an SI prefix before the unit code, such as "kg" for kilogram.
local SIprefixes = {
-- The prefix field is what the prefix should be, if different from the prefix used.
['Q'] = { exponent = 30, name = 'quetta', },
['R'] = { exponent = 27, name = 'ronna', },
['Y'] = { exponent = 24, name = 'yotta', },
['Z'] = { exponent = 21, name = 'zetta', },
['E'] = { exponent = 18, name = 'exa' , },
['P'] = { exponent = 15, name = 'peta' , },
['T'] = { exponent = 12, name = 'tera' , },
['G'] = { exponent = 9, name = 'giga' , },
['M'] = { exponent = 6, name = 'mega' , },
['k'] = { exponent = 3, name = 'kilo' , },
['h'] = { exponent = 2, name = 'hecto', },
['da']= { exponent = 1, name = 'deca' , name_us = 'deka' },
['d'] = { exponent = -1, name = 'deci' , },
['c'] = { exponent = -2, name = 'centi', },
['m'] = { exponent = -3, name = 'milli', },
['μ'] = { exponent = -6, name = 'micro', }, -- key = 'GREEK SMALL LETTER MU' (U+03BC) utf-8 CE BC
['µ'] = { exponent = -6, name = 'micro', prefix = 'μ' }, -- key = 'MICRO SIGN' (U+00B5) utf-8 C2 B5
['u'] = { exponent = -6, name = 'micro', prefix = 'μ' }, -- not an SI prefix, but allow for people typing this
['n'] = { exponent = -9, name = 'nano' , },
['p'] = { exponent =-12, name = 'pico' , },
['f'] = { exponent =-15, name = 'femto', },
['a'] = { exponent =-18, name = 'atto' , },
['z'] = { exponent =-21, name = 'zepto', },
['y'] = { exponent =-24, name = 'yocto', },
['r'] = { exponent =-27, name = 'ronto', },
['q'] = { exponent =-30, name = 'quecto', },
}
-- Some units can be qualified with one of the following prefixes, when linked.
local customary_units = {
{ "US", link = "United States customary units" },
{ "U.S.", link = "United States customary units" },
{ "imperial", link = "Imperial units" },
{ "imp", link = "Imperial units" },
}
-- Names when using engineering notation (a prefix of "eN" where N is a number; example "e6km").
-- key = { "name", link = "article title", exponent = numeric_key_value }
-- If lk=on and link is defined, the name of the number will appear as a link.
local eng_scales = {
["3"] = { "thousand", exponent = 3 },
["6"] = { "million", exponent = 6 },
["9"] = { "billion", link = "1000000000 (number)", exponent = 9 },
["12"] = { "trillion", link = "1000000000000 (number)", exponent = 12 },
["15"] = { "quadrillion", link = "1000000000000000 (number)", exponent = 15 },
}
local all_categories = {
unit = "[[Category:Convert errors]]",
option = "[[Category:Convert errors]]",
warning = '[[Category:Convert invalid options]]',
tracking = '[[Category:Convert tracking]]',
}
-- For some error messages, the following puts the wanted style around
-- each unit code marked like '...%{ft%}...'.
local unitcode_regex = '%%([{}])'
local unitcode_replace = { ['{'] = '"', ['}'] = '"' } -- no longer need the more elaborate substitute used before 2013-09-28
-- All messages that may be displayed if a problem occurs.
local all_messages = {
-- Message format string: $1=title, $2=text, $3=category, $4=anchor.
-- Each displayed message starts with "Convert:" so can easily locate by searching article.
cvt_format = '<sup class="noprint Inline-Template" style="white-space:nowrap;">[<i>[[Help:Convert messages#$4|<span title="Convert: $1">convert: $2</span>]]</i>]</sup>$3<span class="error"></span>',
cvt_format2 = '<sup class="noprint Inline-Template" style="white-space:nowrap;">[[Help:Convert messages#$4|<span title="Convert: $1">$2</span>]]</sup>$3<span class="error"></span>',
cvt_format_preview = '<strong class="error">Error in convert: $1 [[Help:Convert messages#$4|(help)]]</strong>$3',
-- Each of following messages is a table:
-- { [1] = 'title', -- mouseover title text
-- [2] = 'text', -- link text displayed in article
-- [3] = 'category key', -- key to lookup category in all_categories
-- [4] = 'anchor', -- anchor for link to relevant section on help page
-- regex = gsub_regex,
-- replace = gsub_table,
-- } Mouseover title text Link text CatKey Anchor
cvt_bad_input = { 'input "$1" must be a number and unit' , 'invalid input' , 'option', 'invalid_input' },
cvt_bad_num = { 'Value "$1" must be a number' , 'invalid number' , 'option', 'invalid_number' },
cvt_big_prec = { 'Precision "$1" is too large' , 'precision too large' , 'option', 'precision_too_large' },
cvt_invalid_num = { 'Number has overflowed' , 'number overflow' , 'option', 'number_overflow' },
cvt_no_num = { 'Needs the number to be converted' , 'needs a number' , 'option', 'needs_number' },
cvt_no_num2 = { 'Needs another number for a range' , 'needs another number', 'option', 'needs_another_number' },
cvt_bad_altitude = { '"$1" needs an integer' , 'invalid altitude' , 'option', 'invalid_altitude' },
cvt_bad_frac = { '"$1" needs an integer above 1' , 'invalid fraction' , 'option', 'invalid_fraction' },
cvt_bad_prec = { 'Precision "$1" must be an integer' , 'invalid precision' , 'option', 'invalid_precision' },
cvt_bad_sigfig = { '"$1" needs a positive integer' , 'invalid sigfig' , 'option', 'invalid_sigfig' },
cvt_empty_option = { 'Ignored empty option "$1"' , 'empty option' , 'option', 'empty_option' },
cvt_deprecated = { 'Option "$1" is deprecated' , '*' , 'option', 'deprecated_option', format = 'cvt_format2', nowarn = true },
cvt_no_spell = { 'Spelling is not available' , 'bug, ask for help' , 'option', 'ask_for_help' },
cvt_unknown_option = { 'Ignored invalid option "$1"' , 'invalid option' , 'option', 'invalid_option' },
cvt_wd_fail = { 'Unable to access Wikidata' , 'wikidata problem' , 'option', 'wikidata_problem' },
cvt_bad_default = { 'Unit "$1" has an invalid default' , 'bug, ask for help' , 'unit' , 'ask_for_help' },
cvt_bad_unit = { 'Unit "$1" is invalid here' , 'unit invalid here' , 'unit' , 'unit_invalid_here' },
cvt_no_default = { 'Unit "$1" has no default output unit' , 'bug, ask for help' , 'unit' , 'ask_for_help' },
cvt_no_unit = { 'Needs name of unit' , 'needs unit name' , 'unit' , 'needs_unit_name' },
cvt_unknown = { 'Unit name "$1" is not known' , 'unknown unit' , 'unit' , 'unknown_unit' },
cvt_should_be = { '$1' , 'ambiguous unit' , 'unit' , 'ambiguous_unit', regex = unitcode_regex, replace = unitcode_replace },
cvt_mismatch = { 'Cannot convert "$1" to "$2"' , 'unit mismatch' , 'unit' , 'unit_mismatch' },
cvt_bug_convert = { 'Bug: Cannot convert between specified units', 'bug, ask for help' , 'unit' , 'ask_for_help' },
cvt_lookup = { 'Unit "$1" is incorrectly defined' , 'bug, ask for help' , 'unit' , 'ask_for_help' },
}
-- Text to join input value/unit with output value/unit.
local disp_joins = {
-- [1]=before output, [2]=after output, [3]=between outputs in a combination; default "; "
-- [wantname] gives default abbr=off
["or"] = { " or " , "" , " or ", wantname = true },
["sqbr-sp"] = { " [" , "]" },
["sqbr-nbsp"] = { " [" , "]" },
["comma"] = { ", " , "" , ", " },
["semicolon"] = { "; " , "" },
["slash-sp"] = { " / " , "" , wantname = true },
["slash-nbsp"] = { " / ", "" , wantname = true },
["slash-nosp"] = { "/" , "" , wantname = true },
["b"] = { " (" , ")" },
["(or)"] = { " (" , ")", " or " },
["br"] = { "<br />" , "" , wantname = true },
["br()"] = { "<br />(" , ")", wantname = true },
}
-- Text to separate values in a range.
local range_types = {
-- Specifying a table requires either:
-- * "off" and "on" values (for "abbr=off" and "abbr=on"), or
-- * "input" and "output" values (for LHS and RHS);
-- other fields are optional.
-- When "adj=on|abbr=off" applies, spaces in range text are replaced with hyphens.
-- With "exception = true", that also occurs with "adj=on|abbr=on".
-- If "adj" is defined here, that text (unchanged) is used with "adj=on".
["+"] = " + ",
[","] = ", ",
[", and"] = ", and ",
[", or"] = ", or ",
["by"] = " by ",
["-"] = "–",
["to about"] = " to about ",
["and"] = { off = " and ", on = " and ", exception = true },
["and(-)"] = { input = " and ", output = "–" },
["or"] = { off = " or " , on = " or " , exception = true },
["to"] = { off = " to " , on = " to " , exception = true },
["to(-)"] = { input = " to ", output = "–" },
["+/-"] = { off = " ± ", on = " ± ", adj = " ± ", is_range_change = true },
["by(x)"] = { input = " by ", output = " × ", out_range_x = true },
["x"] = { off = " by ", on = " × ", abbr_range_x = true },
["xx"] = " × ",
["*"] = "×",
["/"] = " / ", -- for a table of high/low temperatures with {{convert|83|/|63|F|disp=br()|abbr=values}}
}
local range_aliases = {
-- ["alternative name for a range"] = "standard range name"
["–"] = "-",
["–"] = "-",
["×"] = "x",
["×"] = "x",
["±"] = "+/-",
["±"] = "+/-",
}
-- Convert accepts range text delimited with whitespace, for example, {{convert|1 to 2|ft}}.
-- In addition, the following "words" are accepted without spaces, for example, {{convert|1-2|ft}}.
-- Words must be in correct order for searching, for example, 'x' after 'xx'.
local range_words = { '-', '–', 'xx', 'x', '*' }
local ranges = {
types = range_types,
aliases = range_aliases,
words = range_words,
}
-- Valid option names.
local en_option_name = {
-- ["local text for option name"] = "en name used in this module"
["$"] = "$",
["abbr"] = "abbr",
["adj"] = "adj",
["altitude_ft"] = "altitude_ft",
["altitude_m"] = "altitude_m",
["comma"] = "comma",
["debug"] = "debug",
["disp"] = "disp",
["frac"] = "frac",
["input"] = "input",
["lang"] = "lang",
["link"] = "lk",
["lk"] = "lk",
["order"] = "order",
["qid"] = "qid",
["qual"] = "qual",
["qualifier"] = "qual",
["round"] = "round",
["sigfig"] = "sigfig",
["sing"] = "adj", -- "sing" is an old alias for "adj"
["sortable"] = "sortable",
["sp"] = "sp",
["spell"] = "spell",
["stylein"] = "stylein",
["styleout"] = "styleout",
["tracking"] = "tracking",
}
-- Valid option values.
-- Convention: parms.opt_xxx refers to an option that is set here
-- (not intended to be set by the template which invokes this module).
-- Example: At enwiki, "abbr" includes:
-- ["values"] = "opt_values"
-- As a result, if the template uses abbr=values, Module:Convert sets:
-- parms["opt_values"] = true
-- parms["abbr"] = nil
-- Therefore parms.abbr will be nil, or will have one of the listed values
-- that do not start with "opt_".
-- An option value of form "xxx?" is the same as "xxx" but shows the input as deprecated.
-- Options removed in January 2018 with remnants still in Module:Convert:
-- abbr=mos (in a range, repeat the input unit)
-- adj=1 (set opt_singular to make the unit name singular when 0 < abs(value) <= 1)
local en_option_value = {
["$"] = 'TEXT', -- TEXT should be a currency symbol that will be used instead of "$"
["abbr"] = {
-- ["local text for option value"] = "en value used in this module"
["def"] = "", -- ignored (some wrapper templates call convert with "abbr=def" to mean "default abbreviation")
["h"] = "on", -- abbr=on + use "h" for hand unit (default)
["hh"] = "opt_hand_hh", -- abbr=on + use "hh" for hand unit
["in"] = "in", -- use symbol for LHS unit
["none"] = "off", -- old name for "off"
["off"] = "off", -- use name for all units
["on"] = "on", -- use symbol for all units
["out"] = "out", -- use symbol for RHS unit (default)
["unit"] = "unit", -- abbr=on but abbreviate units only: e6km → million km (not ×10⁶ km)
["values"] = "opt_values", -- show only input and output numbers, not units
["~"] = "opt_also_symbol", -- show input unit symbol as well as name
},
["adj"] = {
["mid"] = "opt_adjectival, opt_adj_mid", -- adj=on with user-specified text after input unit (between input and output)
["off"] = "", -- ignored (off is the default)
["on"] = "opt_adjectival", -- unit name is singular and hyphenated
["pre"] = "opt_one_preunit", -- user-specified text before input unit
["ri0"] = "opt_ri=0", -- round input with precision = 0
["ri1"] = "opt_ri=1", -- round input with precision = 1
["ri2"] = "opt_ri=2", -- round input with precision = 2
["ri3"] = "opt_ri=3", -- round input with precision = 3
["~"] = "opt_also_symbol", -- same as abbr=~ so can have {{convert|1|C|K|abbr=off|adj=~}}
},
["altitude_ft"] = 'INTEGER',
["altitude_m"] = 'INTEGER',
["comma"] = {
["5"] = "opt_comma5", -- only use numsep grouping if 5 or more digits
["gaps"] = "opt_gaps", -- use gaps, not numsep, to separate groups of digits
["gaps3"] = "opt_gaps, opt_gaps3", -- group only in threes rather than default of no gap before a single digit after decimal mark
["off"] = "opt_nocomma", -- no numsep in input or output numbers
},
["debug"] = {
["yes"] = "opt_sortable_debug", -- make the normally hidden sort key visible
},
["disp"] = {
["5"] = "opt_round=5?", -- round output value to nearest 5
["b"] = "b", -- join: '(...)'
["(or)"] = "(or)", -- join: '(...)' with 'or' between outputs in a combination
["br"] = "br", -- join: '<br />'
["br()"] = "br()", -- join: '<br />(...)'
["comma"] = "comma", -- join: ','
["flip"] = "opt_flip", -- reverse order of input/output
["number"] = "opt_output_number_only", -- display output value (not input, and not output symbol/name)
["or"] = "or", -- join: 'or'
["out"] = "opt_output_only",
["output number only"] = "opt_output_number_only",
["output only"] = "opt_output_only",
["preunit"] = "opt_two_preunits", -- user-specified text before input and output units
["semicolon"] = "semicolon", -- join: ';'
["sqbr"] = "sqbr", -- join: '[...]'
["table"] = "opt_table", -- output is suitable for a table cell with align="right"
["tablecen"] = "opt_tablecen", -- output is suitable for a table cell with align="center"
["unit"] = "opt_input_unit_only", -- display input symbol/name (not output, and not input value)
["unit or text"] = "opt_input_unit_only, opt_ignore_error", -- display input symbol/name, or given unit code if not known
["unit2"] = "opt_output_unit_only",
["x"] = "x", -- join: <first>...<second> (user-specified text)
},
["frac"] = 'INTEGER',
["input"] = 'TEXT', -- TEXT should be <value><space><unitcode> or <wikidata-property-id>
["lang"] = { -- language for output digits (both en and local digits are always accepted for input)
["en"] = "opt_lang_en", -- use en digits for numbers, regardless of local language
["local"] = "opt_lang_local", -- use local digits for numbers (default, although config can change default to en)
},
["lk"] = {
["in"] = "in", -- link LHS unit name or symbol
["off"] = "off", -- do not link: same as default except for hand unit
["on"] = "on", -- link all unit names or symbols (but not twice for the same unit)
["out"] = "out", -- link RHS unit name or symbol
},
["order"] = {
["flip"] = "opt_flip", -- reverse order of input/output
["out"] = "opt_order_out", -- do not show input; instead, use order in output combination, with the first output shown as the input
},
["qid"] = 'TEXT', -- TEXT should be a Wikidata Q item identifier
["qual"] = 'TEXT', -- TEXT should be a Wikidata Q item identifier
["round"] = {
["0.5"] = "opt_round=0.5", -- round output value to nearest 0.5
["5"] = "opt_round=5", -- round output value to nearest 5
["10"] = "opt_round=10", -- round output value to nearest 10 (same as but clearer than "|-1")
["25"] = "opt_round=25", -- round output value to nearest 25
["50"] = "opt_round=50", -- round output value to nearest 50
["each"] = "opt_round_each", -- using default precision in a range, round each output separately (default uses highest precision of each item in range)
},
["sigfig"] = 'INTEGER',
["sortable"] = {
["off"] = "", -- ignored (off is the default)
["on"] = "opt_sortable_on", -- output sort key for use in a sortable table, based on value from converting to a standard base unit
["debug"] = "opt_sortable_on, opt_sortable_debug", -- |sortable=debug is the same as |sortable=on|debug=yes
},
["sp"] = {
["us"] = "opt_sp_us", -- use U.S. spelling (like "meter" instead of default "metre")
},
["spell"] = { -- only English spelling is supported; not scientific notation; only some fractions
["in"] = "opt_spell_in", -- spell input value in words
["In"] = "opt_spell_in, opt_spell_upper", -- spell input value in words with first letter uppercase
["on"] = "opt_spell_in, opt_spell_out", -- spell input and output values in words
["On"] = "opt_spell_in, opt_spell_out, opt_spell_upper", -- same, with first letter of first word in result uppercase
["us"] = "opt_sp_us", -- use U.S. spelling; same as sp=us so spell=us also works
},
["stylein"] = 'TEXT',
["styleout"] = 'TEXT',
["tracking"] = 'TEXT',
}
local titles = {
["frac"] = "Fraction/styles.css",
["sfrac"] = "Sfrac/styles.css",
}
return {
SIprefixes = SIprefixes,
all_categories = all_categories,
all_messages = all_messages,
currency = { ['$'] = true, ['£'] = true, ['€'] = true, ['₱'] = true, ['₽'] = true, ['¥'] = true },
customary_units = customary_units,
disp_joins = disp_joins,
en_option_name = en_option_name,
en_option_value = en_option_value,
eng_scales = eng_scales,
ranges = ranges,
titles = titles,
}
d9f24f7b3c125178aa827b8e2b4ad1e7ba143f48
Template:Sfrac
10
729
1121
2025-02-27T18:27:09Z
wikipedia>Great Brightstar
0
Additional fix
wikitext
text/x-wiki
{{ {{{|safesubst:}}}#invoke:Unsubst||$B=<templatestyles src="Sfrac/styles.css" /><span class="sfrac">⁠{{#if:{{{3|}}}|{{{1}}}<span class="sr-only">+</span>}}<!--
--><span class="tion" {{#if:{{{font-size|}}}|style="font-size:{{{font-size}}}"}}><!--
--><span class="num">{{#if:{{{3|}}}|{{{2}}}|{{#if:{{{2|}}}|{{{1}}}|1}}}}</span><!--
--><span class="sr-only">/</span><!--
--><span class="den">{{{3|{{{2|{{{1|1}}}}}}}}}</span><!--
--></span><!--
-->⁠</span>}}<noinclude>
{{documentation}}
<!-- Add categories to /doc subpage, not here. -->
</noinclude>
1a4f22ed67a613ab0f1d9abf9816187efc00f50a
Module:Hatnote
828
338
443
2025-03-18T15:47:33Z
wikipedia>Ahecht
0
Revert
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Hatnote --
-- --
-- This module produces hatnote links and links to related articles. It --
-- implements the {{hatnote}} and {{format link}} meta-templates and includes --
-- helper functions for other Lua hatnote modules. --
--------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local checkTypeForNamedArg = libraryUtil.checkTypeForNamedArg
local mArguments -- lazily initialise [[Module:Arguments]]
local yesno -- lazily initialise [[Module:Yesno]]
local formatLink -- lazily initialise [[Module:Format link]] ._formatLink
local p = {}
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
local function getArgs(frame)
-- Fetches the arguments from the parent frame. Whitespace is trimmed and
-- blanks are removed.
mArguments = require('Module:Arguments')
return mArguments.getArgs(frame, {parentOnly = true})
end
local function removeInitialColon(s)
-- Removes the initial colon from a string, if present.
return s:match('^:?(.*)')
end
function p.defaultClasses(inline)
-- Provides the default hatnote classes as a space-separated string; useful
-- for hatnote-manipulation modules like [[Module:Hatnote group]].
return
(inline == 1 and 'hatnote-inline' or 'hatnote') .. ' ' ..
'navigation-not-searchable'
end
function p.disambiguate(page, disambiguator)
-- Formats a page title with a disambiguation parenthetical,
-- i.e. "Example" → "Example (disambiguation)".
checkType('disambiguate', 1, page, 'string')
checkType('disambiguate', 2, disambiguator, 'string', true)
disambiguator = disambiguator or 'disambiguation'
return mw.ustring.format('%s (%s)', page, disambiguator)
end
function p.findNamespaceId(link, removeColon)
-- Finds the namespace id (namespace number) of a link or a pagename. This
-- function will not work if the link is enclosed in double brackets. Colons
-- are trimmed from the start of the link by default. To skip colon
-- trimming, set the removeColon parameter to false.
checkType('findNamespaceId', 1, link, 'string')
checkType('findNamespaceId', 2, removeColon, 'boolean', true)
if removeColon ~= false then
link = removeInitialColon(link)
end
local namespace = link:match('^(.-):')
if namespace then
local nsTable = mw.site.namespaces[namespace]
if nsTable then
return nsTable.id
end
end
return 0
end
function p.makeWikitextError(msg, helpLink, addTrackingCategory, title)
-- Formats an error message to be returned to wikitext. If
-- addTrackingCategory is not false after being returned from
-- [[Module:Yesno]], and if we are not on a talk page, a tracking category
-- is added.
checkType('makeWikitextError', 1, msg, 'string')
checkType('makeWikitextError', 2, helpLink, 'string', true)
yesno = require('Module:Yesno')
title = title or mw.title.getCurrentTitle()
-- Make the help link text.
local helpText
if helpLink then
helpText = ' ([[' .. helpLink .. '|help]])'
else
helpText = ''
end
-- Make the category text.
local category
if not title.isTalkPage -- Don't categorise talk pages
and title.namespace ~= 2 -- Don't categorise userspace
and yesno(addTrackingCategory) ~= false -- Allow opting out
then
category = 'Hatnote templates with errors'
category = mw.ustring.format(
'[[%s:%s]]',
mw.site.namespaces[14].name,
category
)
else
category = ''
end
return mw.ustring.format(
'<strong class="error">Error: %s%s.</strong>%s',
msg,
helpText,
category
)
end
local curNs = mw.title.getCurrentTitle().namespace
p.missingTargetCat =
--Default missing target category, exported for use in related modules
((curNs == 0) or (curNs == 14)) and
'Articles with hatnote templates targeting a nonexistent page' or nil
function p.quote(title)
--Wraps titles in quotation marks. If the title starts/ends with a quotation
--mark, kerns that side as with {{-'}}
local quotationMarks = {
["'"]=true, ['"']=true, ['“']=true, ["‘"]=true, ['”']=true, ["’"]=true
}
local quoteLeft, quoteRight = -- Test if start/end are quotation marks
quotationMarks[string.sub(title, 1, 1)],
quotationMarks[string.sub(title, -1, -1)]
if quoteLeft or quoteRight then
title = mw.html.create("span"):wikitext(title)
end
if quoteLeft then title:css("padding-left", "0.15em") end
if quoteRight then title:css("padding-right", "0.15em") end
return '"' .. tostring(title) .. '"'
end
--------------------------------------------------------------------------------
-- Hatnote
--
-- Produces standard hatnote text. Implements the {{hatnote}} template.
--------------------------------------------------------------------------------
p[''] = function (frame) return p.hatnote(frame:newChild{ title = "Template:Hatnote" }) end
function p.hatnote(frame)
local args = getArgs(frame)
local s = args[1]
if not s then
return p.makeWikitextError(
'no text specified',
'Template:Hatnote#Errors',
args.category
)
end
return p._hatnote(s, {
extraclasses = args.extraclasses,
selfref = args.selfref
})
end
function p._hatnote(s, options)
checkType('_hatnote', 1, s, 'string')
checkType('_hatnote', 2, options, 'table', true)
options = options or {}
local inline = options.inline
local hatnote = mw.html.create(inline == 1 and 'span' or 'div')
local extraclasses
if type(options.extraclasses) == 'string' then
extraclasses = options.extraclasses
end
hatnote
:attr('role', 'note')
:addClass(p.defaultClasses(inline))
:addClass(extraclasses)
:addClass(options.selfref and 'selfref' or nil)
:wikitext(s)
return mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Module:Hatnote/styles.css' }
} .. tostring(hatnote)
end
return p
e4b658e3483374de2bebf772f3d19aaa713ca3f5
Module:Val
828
718
1099
2025-06-01T05:39:35Z
wikipedia>Johnuniq
0
change 0.3em spacing to 0.225em (same total space as old code) per [[Template talk:Val#Proposal to reduce spacing around ±]]
Scribunto
text/plain
-- For Template:Val, output a number and optional unit.
-- Format options include scientific and uncertainty notations.
local numdot = '.' -- decimal mark (use ',' for Italian)
local numsep = ',' -- group separator (use ' ' for Italian)
local mtext = {
-- Message and other text that should be localized.
['mt-bad-exponent'] = 'exponent parameter (<b>e</b>)',
['mt-parameter'] = 'parameter ',
['mt-not-number'] = 'is not a valid number',
['mt-cannot-range'] = 'cannot use a range if the first parameter includes "e"',
['mt-need-range'] = 'needs a range in parameter 2',
['mt-should-range'] = 'should be a range',
['mt-cannot-with-e'] = 'cannot be used if the first parameter includes "e"',
['mt-not-range'] = 'does not accept a range',
['mt-cannot-e'] = 'cannot use e notation',
['mt-too-many-parameter'] = 'too many parameters',
['mt-need-number'] = 'need a number after the last parameter because it is a range.',
['mt-ignore-parameter4'] = 'Val parameter 4 ignored',
['mt-val-not-supported'] = 'Val parameter "%s=%s" is not supported',
['mt-invalid-scale'] = 'Unit "%s" has invalid scale "%s"',
['mt-both-u-ul'] = 'unit (<b>u</b>) and unit with link (<b>ul</b>) are both specified, only one is allowed.',
['mt-both-up-upl'] = 'unit per (<b>up</b>) and unit per with link (<b>upl</b>) are both specified, only one is allowed.',
}
local data_module = 'Module:Val/units'
local convert_module = 'Module:Convert'
local function valerror(msg, nocat, iswarning)
-- Return formatted message text for an error or warning.
-- Can append "#FormattingError" to URL of a page with a problem to find it.
local anchor = '<span id="FormattingError"></span>'
local body, category
if nocat or mw.title.getCurrentTitle():inNamespaces(1, 2, 3, 5) then
-- No category in Talk, User, User_talk, or Wikipedia_talk.
category = ''
else
category = '[[Category:Pages with incorrect formatting templates use]]'
end
iswarning = false -- problems are infrequent so try showing large error so editor will notice
if iswarning then
body = '<sup class="noprint Inline-Template" style="white-space:nowrap;">' ..
'[[Template:Val|<span title="' ..
msg:gsub('"', '"') ..
'">warning</span>]]</sup>'
else
body = '<strong class="error">' ..
'Error in {{[[Template:val|val]]}}: ' ..
msg ..
'</strong>'
end
return anchor .. body .. category
end
local range_types = {
-- No need for ' ' because nowrap applies to all output.
[","] = ", ",
["by"] = " by ",
["-"] = "–",
["–"] = "–",
["and"] = " and ",
["or"] = " or " ,
["to"] = " to " ,
["x"] = " × ",
["×"] = " × ",
["/"] = "/",
}
local range_repeat_unit = {
-- WP:UNIT wants unit repeated when a "multiply" range is used.
["x"] = true,
["×"] = true,
}
local function extract_item(index, numbers, arg)
-- Extract an item from arg and store the result in numbers[index].
-- If no argument or if argument is valid, return nil (no error);
-- otherwise, return an error message.
-- The stored result is:
-- * a table for a number (empty if there was no specified number); or
-- * a string for range text
-- Input like 1e3 is regarded as invalid for all except argument 1
-- which accepts e notation as an alternative to the 'e' argument.
-- Input group separators are removed.
local which = index
local function fail(msg)
local description
if which == 'e' then
description = mtext['mt-bad-exponent']
else
description = mtext['mt-parameter'] .. which
end
return description .. ' ' .. (msg or mtext['mt-not-number']) .. '.'
end
local result = {}
local range = range_types[arg]
if range then
if type(index) == 'number' and (index % 2 == 0) then
if index == 2 then
if numbers[1] and numbers[1].exp then
return fail(mtext['mt-cannot-range'])
end
numbers.has_ranges = true
else
if not numbers.has_ranges then
return fail(mtext['mt-need-range'])
end
end
numbers[index] = range
if range_repeat_unit[arg] then
-- Any "repeat" range forces unit (if any) to be repeated for all items.
numbers.isrepeat = true
end
return nil
end
return fail(mtext['mt-not-range'])
end
if numbers.has_ranges and type(index) == 'number' and (index % 2 == 0) then
return fail(mtext['mt-should-range'])
end
if index == 'e' then
local e = numbers[1] and numbers[1].exp
if e then
if arg then
return fail(mtext['mt-cannot-with-e'])
end
arg = e
which = 1
end
end
if arg and arg ~= '' then
arg = arg:gsub(numsep, '')
if numdot ~= '.' then
arg = arg:gsub(numdot, '.')
end
if arg:sub(1, 1) == '(' and arg:sub(-1) == ')' then
result.parens = true
arg = arg:sub(2, -2)
end
local a, b = arg:match('^(.+)[Ee](.+)$')
if a then
if index == 1 then
arg = a
result.exp = b
else
return fail(mtext['mt-cannot-e'])
end
end
local isnegative, propersign, prefix
local minus = '−'
prefix, arg = arg:match('^(.-)([%d.]+)$')
local value = tonumber(arg)
if not value then
return fail()
end
if arg:sub(1, 1) == '.' then
arg = '0' .. arg
end
if prefix == '' then
-- Ignore.
elseif prefix == '±' then
-- Display for first number, ignore for others.
if index == 1 then
propersign = '±'
end
elseif prefix == '+' then
propersign = '+'
elseif prefix == '-' or prefix == minus then
propersign = minus
isnegative = true
else
return fail()
end
result.clean = arg
result.sign = propersign or ''
result.value = isnegative and -value or value
end
numbers[index] = result
return nil -- no error
end
local function get_args(numbers, args)
-- Extract arguments and store the results in numbers.
-- Return nothing (no error) if ok; otherwise, return an error message.
for index = 1, 99 do
local which = index
local arg = args[which] -- has been trimmed
if not arg then
which = 'e'
arg = args[which]
end
local msg = extract_item(which, numbers, arg)
if msg then
return msg
end
if which == 'e' then
break
end
if index > 19 then
return mtext['mt-too-many-parameter']
end
end
if numbers.has_ranges and (#numbers % 2 == 0) then
return mtext['mt-need-number']
end
end
local function get_scale(text, ucode)
-- Return the value of text as a number, or throw an error.
-- This supports extremely basic expressions of the form:
-- a / b
-- a ^ b
-- where a and b are numbers or 'pi'.
local n = tonumber(text)
if n then
return n
end
n = text:gsub('pi', math.pi)
for _, op in ipairs({ '/', '^' }) do
local a, b = n:match('^(.-)' .. op .. '(.*)$')
if a then
a = tonumber(a)
b = tonumber(b)
if a and b then
if op == '/' then
return a / b
elseif op == '^' then
return a ^ b
end
end
break
end
end
error(string.format(mtext['mt-invalid-scale'], ucode, text))
end
local function get_builtin_unit(ucode, definitions)
-- Return table of information for the specified built-in unit, or nil if not known.
-- Each defined unit code must be followed by two spaces (not tab characters).
local _, pos = definitions:find('\n' .. ucode .. ' ', 1, true)
if pos then
local endline = definitions:find('%s*\n', pos)
if endline then
local result = {}
local n = 0
local text = definitions:sub(pos + 1, endline - 1):gsub('%s%s+', '\t')
for item in (text .. '\t'):gmatch('(%S.-)\t') do
if item == 'ALIAS' then
result.alias = true
elseif item == 'ANGLE' then
result.isangle = true
result.nospace = true
elseif item == 'NOSPACE' then
result.nospace = true
elseif item == 'SI' then
result.si = true
else
n = n + 1
if n == 1 then
local link, symbol = item:match('^%[%[([^|]+)|(.+)%]%]$')
if link then
result.symbol = symbol
result.link = link
n = 2
else
result.symbol = item
end
elseif n == 2 then
result.link = item
elseif n == 3 then
result.scale_text = item
result.scale = get_scale(item, ucode)
else
result.more_ignored = item
break
end
end
end
if result.si then
local s = result.symbol
if ucode == 'mc' .. s or ucode == 'mu' .. s then
result.ucode = 'µ' .. s -- unit code for convert should be this
end
end
if n >= 2 or (n >= 1 and result.alias) then
return result
end
-- Ignore invalid definition, treating it as a comment.
end
end
end
local function convert_lookup(ucode, value, scaled_top, want_link, si, options)
local lookup = require(convert_module)._unit
return lookup(ucode, {
value = value,
scaled_top = scaled_top,
link = want_link,
si = si,
sort = options.sortable,
})
end
local function get_unit(ucode, value, scaled_top, options)
local want_link = options.want_link
if scaled_top then
want_link = options.want_per_link
end
local data = mw.loadData(data_module)
local result = options.want_longscale and
get_builtin_unit(ucode, data.builtin_units_long_scale) or
get_builtin_unit(ucode, data.builtin_units)
local si, use_convert
if result then
if result.alias then
ucode = result.symbol
use_convert = true
end
if result.scale then
-- Setting si means convert will use the unit as given, and the sort key
-- will be calculated from the value without any extra scaling that may
-- occur if convert found the unit code. For example, if val defines the
-- unit 'year' with a scale and if si were not set, convert would also apply
-- its own scale because convert knows that a year is 31,557,600 seconds.
si = { result.symbol, result.link }
value = value * result.scale
end
if result.si then
ucode = result.ucode or ucode
si = { result.symbol, result.link }
use_convert = true
end
else
result = {}
use_convert = true
end
local convert_unit = convert_lookup(ucode, value, scaled_top, want_link, si, options)
result.sortkey = convert_unit.sortspan
if use_convert then
result.text = convert_unit.text
result.scaled_top = convert_unit.scaled_value
else
if want_link then
result.text = '[[' .. result.link .. '|' .. result.symbol .. ']]'
else
result.text = result.symbol
end
result.scaled_top = value
end
return result
end
local function makeunit(value, options)
-- Return table of information for the requested unit and options, or
-- return nil if no unit.
options = options or {}
local unit
local ucode = options.u
local percode = options.per
if ucode then
unit = get_unit(ucode, value, nil, options)
elseif percode then
unit = { nospace = true, scaled_top = value }
else
return nil
end
local text = unit.text or ''
local sortkey = unit.sortkey
if percode then
local function bracketed(code, text)
return code:find('[*./]') and '(' .. text .. ')' or text
end
local perunit = get_unit(percode, 1, unit.scaled_top, options)
text = (ucode and bracketed(ucode, text) or '') ..
'/' .. bracketed(percode, perunit.text)
sortkey = perunit.sortkey
end
if not (unit.nospace or options.nospace) then
text = ' ' .. text
end
return { text = text, isangle = unit.isangle, sortkey = sortkey }
end
local function list_units(mode)
-- Return wikitext to list the built-in units.
-- A unit code should not contain wikimarkup so don't bother escaping.
local data = mw.loadData(data_module)
local definitions = data.builtin_units .. data.builtin_units_long_scale
local last_was_blank = true
local n = 0
local result = {}
local function add(line)
if line == '' then
last_was_blank = true
else
if last_was_blank and n > 0 then
n = n + 1
result[n] = ''
end
last_was_blank = false
n = n + 1
result[n] = line
end
end
local si_prefixes = {
-- These are the prefixes recognized by convert; u is accepted for micro.
y = 'y',
z = 'z',
a = 'a',
f = 'f',
p = 'p',
n = 'n',
u = 'µ',
['µ'] = 'µ',
m = 'm',
c = 'c',
d = 'd',
da = 'da',
h = 'h',
k = 'k',
M = 'M',
G = 'G',
T = 'T',
P = 'P',
E = 'E',
Z = 'Z',
Y = 'Y',
}
local function is_valid(ucode, unit)
if unit and not unit.more_ignored then
assert(type(unit.symbol) == 'string' and unit.symbol ~= '')
if unit.alias then
if unit.link or unit.scale_text or unit.si then
return false
end
end
if unit.si then
if unit.scale_text then
return false
end
ucode = unit.ucode or ucode
local base = unit.symbol
if ucode == base then
unit.display = base
return true
end
local plen = #ucode - #base
if plen > 0 then
local prefix = si_prefixes[ucode:sub(1, plen)]
if prefix and ucode:sub(plen + 1) == base then
unit.display = prefix .. base
return true
end
end
else
unit.display = unit.symbol
return true
end
end
return false
end
local lookup = require(convert_module)._unit
local function show_convert(ucode, unit)
-- If a built-in unit defines a scale or sets the SI flag, any unit defined in
-- convert is not used (the scale or SI prefix's scale is used for a sort key).
-- If there is no scale or SI flag, and the unit is not defined in convert,
-- the sort key may not be correct; this allows such units to be identified.
if not (unit.si or unit.scale_text) then
if mode == 'convert' then
unit.show = not lookup(unit.alias and unit.symbol or ucode).unknown
unit.show_text = 'CONVERT'
elseif mode == 'unknown' then
unit.show = lookup(unit.alias and unit.symbol or ucode).unknown
unit.show_text = 'UNKNOWN'
elseif not unit.alias then
-- Show convert's scale in square brackets ('[1]' for an unknown unit).
-- Don't show scale for an alias because it's misleading for temperature
-- and an alias is probably not useful for anything else.
local scale = lookup(ucode, {value=1, sort='on'}).scaled_value
if type(scale) == 'number' then
scale = string.format('%.5g', scale):gsub('e%+?(%-?)0*(%d+)', 'e%1%2')
else
scale = '?'
end
unit.show = true
unit.show_text = '[' .. scale .. ']'
end
end
end
for line in definitions:gmatch('([^\n]*)\n') do
local pos, _ = line:find(' ', 1, true)
if pos then
local ucode = line:sub(1, pos - 1)
local unit = get_builtin_unit(ucode, '\n' .. line .. '\n')
if is_valid(ucode, unit) then
show_convert(ucode, unit)
local flags, text
if unit.alias then
text = unit.symbol
else
text = '[[' .. unit.link .. '|' .. unit.display .. ']]'
end
if unit.isangle then
unit.nospace = nil -- don't show redundant flag
end
for _, f in ipairs({
{ 'alias', 'ALIAS' },
{ 'isangle', 'ANGLE' },
{ 'nospace', 'NOSPACE' },
{ 'si', 'SI' },
{ 'scale_text', unit.scale_text },
{ 'show', unit.show_text },
}) do
if unit[f[1]] then
local t = f[2]
if t:match('^%u+$') then
t = '<small>' .. t .. '</small>'
end
if flags then
flags = flags .. ' ' .. t
else
flags = t
end
end
end
if flags then
text = text .. ' • ' .. flags
end
add(ucode .. ' = ' .. text .. '<br />')
else
add(line .. ' ◆ <b>invalid definition</b><br />')
end
else
add(line)
end
end
return table.concat(result, '\n')
end
local delimit_groups = require('Module:Gapnum').groups
local function delimit(sign, numstr, fmt)
-- Return sign and numstr (unsigned digits or numdot only) after formatting.
-- Four-digit integers are not formatted with gaps.
fmt = (fmt or ''):lower()
if fmt == 'none' or (fmt == '' and #numstr == 4 and numstr:match('^%d+$')) then
return sign .. numstr
end
-- Group number by integer and decimal parts.
-- If there is no decimal part, delimit_groups returns only one table.
local ipart, dpart = delimit_groups(numstr)
local result
if fmt == 'commas' then
result = sign .. table.concat(ipart, numsep)
if dpart then
result = result .. numdot .. table.concat(dpart)
end
else
-- Delimit with a small gap by default.
local groups = {}
groups[1] = table.remove(ipart, 1)
for _, v in ipairs(ipart) do
table.insert(groups, '<span style="margin-left:.25em;">' .. v .. '</span>')
end
if dpart then
table.insert(groups, numdot .. (table.remove(dpart, 1) or ''))
for _, v in ipairs(dpart) do
table.insert(groups, '<span style="margin-left:.25em;">' .. v .. '</span>')
end
end
result = sign .. table.concat(groups)
end
return result
end
local function sup_sub(sup, sub, align)
-- Return the same result as Module:Su except val defaults to align=right.
if align == 'l' or align == 'left' then
align = 'left'
elseif align == 'c' or align == 'center' then
align = 'center'
else
align = 'right'
end
return '<span style="display:inline-block;margin-bottom:-0.3em;vertical-align:-0.4em;line-height:1.2em;font-size:85%;text-align:' ..
align .. ';">' .. sup .. '<br />' .. sub .. '</span>'
end
local function range_text(items, unit_table, options)
local fmt = options.fmt
local nend = items.nend or ''
if items.isrepeat or unit_table.isangle then
nend = nend .. unit_table.text
end
local text = ''
for i = 1, #items do
if i % 2 == 0 then
text = text .. items[i]
else
text = text .. delimit(items[i].sign, items[i].clean, fmt) .. nend
end
end
return text
end
local function uncertainty_text(uncertainty, unit_table, options)
local angle, text, need_parens
if unit_table.isangle then
angle = unit_table.text
end
local upper = uncertainty.upper or {}
local lower = uncertainty.lower or {}
local uncU = upper.clean
if uncU then
local fmt = options.fmt
local uncL = lower.clean
if uncL then
uncU = delimit('+', uncU, fmt) .. (upper.errend or '')
uncL = delimit('−', uncL, fmt) .. (lower.errend or '')
if angle then
uncU = uncU .. angle
uncL = uncL .. angle
end
text = (angle or '') ..
'<span style="margin-left:0.3em;">' ..
sup_sub(uncU, uncL, options.align) ..
'</span>'
else
if upper.parens then
text = '(' .. uncU .. ')' -- old template did not delimit
else
text = (angle or '') ..
'<span style="margin-left:0.225em;margin-right:0.225em;">±</span>' ..
delimit('', uncU, fmt)
need_parens = true
end
if uncertainty.errend then
text = text .. uncertainty.errend
end
if angle then
text = text .. angle
end
end
else
if angle then
text = angle
end
end
return text, need_parens
end
local function _main(values, unit_spec, options)
if options.sandbox then
data_module = data_module .. '/sandbox'
convert_module = convert_module .. '/sandbox'
end
local action = options.action
if action then
if action == 'list' then
-- Kludge: am using the align parameter (a=xxx) for type of list.
return list_units(options.align)
end
return valerror('invalid action "' .. action .. '".', options.nocat)
end
local number = values.number or (values.numbers and values.numbers[1]) or {}
local e_10 = options.e or {}
local novalue = (number.value == nil and e_10.clean == nil)
local fmt = options.fmt
local want_sort = true
local sortable = options.sortable
if sortable == 'off' or (sortable == nil and novalue) then
want_sort = false
elseif sortable == 'debug' then
-- Same as sortable = 'on' but the sort key is displayed.
else
sortable = 'on'
end
local sort_value = 1
if want_sort then
sort_value = number.value or 1
if e_10.value and sort_value ~= 0 then
-- The 'if' avoids {{val|0|e=1234}} giving an invalid sort_value due to overflow.
sort_value = sort_value * 10^e_10.value
end
end
local unit_table = makeunit(sort_value, {
u = unit_spec.u,
want_link = unit_spec.want_link,
per = unit_spec.per,
want_per_link = unit_spec.want_per_link,
nospace = novalue,
want_longscale = unit_spec.want_longscale,
sortable = sortable,
})
local sortkey
if unit_table then
if want_sort then
sortkey = unit_table.sortkey
end
else
unit_table = { text = '' }
if want_sort then
sortkey = convert_lookup('dummy', sort_value, nil, nil, nil, { sortable = sortable }).sortspan
end
end
local final_unit = unit_table.isangle and '' or unit_table.text
local e_text, n_text, need_parens
local uncertainty = values.uncertainty
if uncertainty then
if number.clean then
n_text = delimit(number.sign, number.clean, fmt) .. (number.nend or '')
local text
text, need_parens = uncertainty_text(uncertainty, unit_table, options)
if text then
n_text = n_text .. text
end
else
n_text = ''
end
else
if values.numbers.isrepeat then
final_unit = ''
end
n_text = range_text(values.numbers, unit_table, options)
need_parens = true
end
if e_10.clean then
if need_parens then
n_text = '(' .. n_text .. ')'
end
e_text = '10<sup>' .. delimit(e_10.sign, e_10.clean, fmt) .. '</sup>'
if number.clean then
e_text = '<span style="margin-left:0.25em;margin-right:0.15em;">×</span>' .. e_text
end
else
e_text = ''
end
local result =
(sortkey or '') ..
(options.prefix or '') ..
n_text ..
e_text ..
final_unit ..
(options.suffix or '')
if result ~= '' then
result = '<span class="nowrap">' .. result .. '</span>'
end
return result .. (options.warning or '')
end
local function check_parameters(args, has_ranges, nocat)
-- Return warning text for the first problem parameter found, or nothing if ok.
local whitelist = {
a = true,
action = true,
debug = true,
e = true,
['end'] = true,
errend = true,
['+errend'] = true,
['-errend'] = true,
fmt = true,
['long scale'] = true,
long_scale = true,
longscale = true,
nocategory = true,
p = true,
s = true,
sortable = true,
u = true,
ul = true,
up = true,
upl = true,
}
for k, v in pairs(args) do
if type(k) == 'string' and not whitelist[k] then
local warning = string.format(mtext['mt-val-not-supported'], k, v)
return valerror(warning, nocat, true)
end
end
if not has_ranges and args[4] then
return valerror(mtext['mt-ignore-parameter4'], nocat, true)
end
end
local function main(frame)
local getArgs = require('Module:Arguments').getArgs
local args = getArgs(frame, {wrappers = { 'Template:Val' }})
local nocat = args.nocategory
local numbers = {} -- table of number tables, perhaps with range text
local msg = get_args(numbers, args)
if msg then
return valerror(msg, nocat)
end
if args.u and args.ul then
return valerror(mtext['mt-both-u-ul'], nocat)
end
if args.up and args.upl then
return valerror(mtext['mt-both-up-upl'], nocat)
end
local values
if numbers.has_ranges then
-- Multiple values with range separators but no uncertainty.
numbers.nend = args['end']
values = {
numbers = numbers,
}
else
-- A single value with optional uncertainty.
local function setfield(i, dst, src)
local v = args[src]
if v then
if numbers[i] then
numbers[i][dst] = v
else
numbers[i] = { [dst] = v }
end
end
end
setfield(1, 'nend', 'end')
setfield(2, 'errend', '+errend')
setfield(3, 'errend', '-errend')
values = {
number = numbers[1],
uncertainty = {
upper = numbers[2],
lower = numbers[3],
errend = args.errend,
}
}
end
local unit_spec = {
u = args.ul or args.u,
want_link = args.ul ~= nil,
per = args.upl or args.up,
want_per_link = args.upl ~= nil,
want_longscale = (args.longscale or args.long_scale or args['long scale']) == 'on',
}
local options = {
action = args.action,
align = args.a,
e = numbers.e,
fmt = args.fmt,
nocat = nocat,
prefix = args.p,
sandbox = string.find(frame:getTitle(), 'sandbox', 1, true) ~= nil,
sortable = args.sortable or (args.debug == 'yes' and 'debug' or nil),
suffix = args.s,
warning = check_parameters(args, numbers.has_ranges, nocat),
}
return _main(values, unit_spec, options)
end
return { main = main, _main = _main }
6a50e544e78223a89c0b012cb5fc6de86419edf8
Module:Val/units
828
719
1101
2025-06-23T22:02:44Z
wikipedia>MSGJ
0
remove superfluous space
Scribunto
text/plain
-- Definitions for units known to val
-- File format is two strings and a return statement with them in it:
-- string in quotes [=[ ... builtin_units ... ]=].
-- string in quotes [=[ ... builtin_units_long_scale ... ]=].
-- First string, builtin_units, is short-scale, second string is long scale.
-- Entry format:
-- One record per line, starting in first column, having 2-4 fields.
-- Field separator: two or more spaces
-- Between first and second fields: two or more spaces
-- Between all other fields: two or more spaces, or one or more tabs
-- Entries without two spaces in them are ignored.
-- There must be a blank line before the first entry and after the last.
-- I.e. the first two and last two characters of the string must be newlines.
-- Format of entry. Two record types:
--
-- One record type is a wikilink:
-- Unit-code [[ pagename | Symbol-accepts-HTML-only ]]
-- Text-field separator is still two spaces. Two spaces not allowed in wikilink.
--
-- The other record type is all fields:
-- Unit-code symbol-accepts-HTML-only pagename#section-OK
--
-- Plus there is an optional field that goes at the end after two or more spaces.
-- Whether it is a number or an equation or the letters SI,
-- any of these three has the same function: a wikitable sorting "scale".
-- It is for sorting, and it works for either record type.
-- Difference is SI can't accept HTML. But SI correctly scales any SI prefix.
-- (Optional fields ALIAS and NOSPACE and ANGLE are for advanced users.)
-- "Invalid unit" error:
-- Using SI requires that the symbol equal unit-code, so never allows HTML.
-- Any difference between SI or symbol must be an SI prefix, such as k, M, or G.
-- A space at the end of an entry is an error. No space at each EOL.
local builtin_units = [=[
== Test ==
Foo [[Hz|<samp>Foo</samp>]]
Baz [[Hertz|baz<sub>0</sub>]]
Baz [[Kelvins|baz<sub>0</sub>]]
Bar [[Foobar|bar<abbr title="super duper">0</abbr>]]
quux [[Foobar|<span title="super duper 2">bar0</span>]]
== Unsorted units ==
c0 [[Speed of light#Numerical value, notation, and units|''c''<sub>0</sub>]]
lbf [[Pound (force)|<span title="pound-force">lb<sub>F</sub></span>]]
N.s [[Newton-second|N⋅s]]
J.K-1 [[Joule per kelvin|J⋅K<sup>−1</sup>]]
C.mol-1 [[Faraday constant|C⋅mol<sup>−1</sup>]]
C/mol [[Faraday constant|C/mol]]
C.kg-1 [[Roentgen (unit)|C⋅kg<sup>−1</sup>]]
C/kg [[Roentgen (unit)|C/kg]]
F.m-1 [[vacuum permittivity|F⋅m<sup>−1</sup>]]
F/m [[vacuum permittivity|F/m]]
e [[Elementary charge|''e'']]
kB [[Kilobyte|kB]] 8e3
KB [[Kilobyte|KB]] 8e3
MB [[Megabyte|MB]] 8e6
GB [[Gigabyte|GB]] 8e9
TB [[Terabyte|TB]] 8e12
lx [[Lux (unit)|lx]]
nat [[nat (unit)|nat]]
== Time and frequency ==
byte/s [[Data rate units|byte/s]] 8
kB/s [[Data rate units#Kilobyte per second|<span title="Kilobytes per second">kB/s</span>]] 8e3
MB/s [[Data rate units#Megabyte per second|<span title="Megabytes per second">MB/s</span>]] 8e6
GB/s [[Data rate units#Gigabyte per second|<span title="Gigabytes per second">GB/s</span>]] 8e9
TB/s [[Data rate units#Terabyte per second|<span title="Terabytes per second">TB/s</span>]] 8e12
bit/s [[Bit per second|bit/s]] 1
bps [[Bit per second|bit/s]] 1
kbit/s [[Kilobit per second|kbit/s]] 1e3
Mbit/s [[Megabit per second|Mbit/s]] 1e6
Gbit/s [[Gigabit per second|Gbit/s]] 1e9
Tbit/s [[Terabit per second|Tbit/s]] 1e12
kT/s [[Transfer (computing)|<span title="Kilotransfers per second">kT/s</span>]] 1e3
MT/s [[Transfer (computing)|<span title="Megatransfers per second">MT/s</span>]] 1e6
GT/s [[Transfer (computing)|<span title="Gigatransfers per second">GT/s</span>]] 1e9
year [[Year|year]] 31557600
years [[Year|years]] 31557600
yr [[Year#Symbols and abbreviations|yr]] 31557600
y [[Year|y]] 31557600
a [[Annum|a]] 31557600
Ga [[Gigaannum|Ga]] 31557600000000000
Ma [[Megaannum|Ma]] 31557600000000
ka [[Kiloannum|ka]] 31557600000
kyr [[kyr|kyr]] 31557600000
kya [[kyr|kya]] 31557600000
myr [[myr|myr]] 31557600000000
mya [[Mya (unit)|mya]] 31557600000000
byr [[Billion years|byr]] 31557600000000000
bya [[Billion years ago|bya]] 31557600000000000
Gyr [[billion years|Gyr]] 31557600000000000
BP [[Before present|BP]]
uBP [[Radiocarbon dating#Calibration|<sup>14</sup>C yr BP]]
BC [[Before Christ|BC]] -1
AD [[Anno Domini|AD]] 1
BCE [[Before the Common Era|BCE]] -1
CE [[Common Era|CE]] 1
JD [[Julian date|JD]] 1
MJD [[Modified Julian date|MJD]] 1
s-1 [[Second|s<sup>−1</sup>]]
s-2 [[Second|s<sup>−2</sup>]]
s2 [[Second|s<sup>2</sup>]]
s [[Second|s]] SI
as [[Attosecond|s]] SI
cs [[Second|s]] SI
das [[Second|s]] SI
ds [[Second|s]] SI
Es [[Second|s]] SI
fs [[Femtosecond|s]] SI
Gs [[Second|s]] SI
hs [[Second|s]] SI
ks [[Second|s]] SI
ms [[Millisecond|s]] SI
µs [[Microsecond|s]] SI
us [[Microsecond|s]] SI
Ms [[Second|s]] SI
ns [[Nanosecond|s]] SI
ps [[Picosecond|s]] SI
Ps [[Second|s]] SI
Ts [[Second|s]] SI
Ys [[Second|s]] SI
ys [[Yoctosecond|s]] SI
Zs [[Second|s]] SI
zs [[Zeptosecond|s]] SI
Hz [[Hertz|Hz]] SI
aHz [[Hertz|Hz]] SI
cHz [[Hertz|Hz]] SI
daHz [[Hertz|Hz]] SI
dHz [[Hertz|Hz]] SI
EHz [[Hertz|Hz]] SI
fHz [[Hertz|Hz]] SI
hHz [[Hertz|Hz]] SI
GHz [[Gigahertz|Hz]] SI
kHz [[Kilohertz|Hz]] SI
MHz [[Megahertz|Hz]] SI
mHz [[Hertz|Hz]] SI
uHz [[Hertz|Hz]] SI
µHz [[Hertz|Hz]] SI
nHz [[Hertz|Hz]] SI
pHz [[Hertz|Hz]] SI
PHz [[Hertz|Hz]] SI
THz [[Hertz|Hz]] SI
yHz [[Hertz|Hz]] SI
YHz [[Hertz|Hz]] SI
zHz [[Hertz|Hz]] SI
ZHz [[Hertz|Hz]] SI
ips [[Inch per second|ips]]
== Length, area, volume ==
Å3 [[Ångström|Å<sup>3</sup>]]
fb-1 [[Barn (unit)#Inverse femtobarn|fb<sup>−1</sup>]]
m-1 [[Metre|m<sup>−1</sup>]]
m-2 [[Square metre|m<sup>−2</sup>]]
m-3 [[Cubic metre|m<sup>−3</sup>]]
km2 [[Square kilometre|km<sup>2</sup>]]
km3 [[Cubic kilometre|km<sup>3</sup>]]
µm2 [[Square metre|µm<sup>2</sup>]]
um2 [[Square metre|µm<sup>2</sup>]]
am2 [[Square metre|am<sup>2</sup>]]
cm2 [[Square centimetre|cm<sup>2</sup>]]
dam2 [[Square metre|dam<sup>2</sup>]]
dm2 [[Square metre|dm<sup>2</sup>]]
Em2 [[Square metre|Em<sup>2</sup>]]
fm2 [[Square metre|fm<sup>2</sup>]]
Gm2 [[Square metre|Gm<sup>2</sup>]]
hm2 [[Square metre|hm<sup>2</sup>]]
mm2 [[Square metre|mm<sup>2</sup>]]
Mm2 [[Square metre|Mm<sup>2</sup>]]
nm2 [[Square metre|nm<sup>2</sup>]]
pm2 [[Square metre|pm<sup>2</sup>]]
Pm2 [[Square metre|Pm<sup>2</sup>]]
Tm2 [[Square metre|Tm<sup>2</sup>]]
ym2 [[Square metre|ym<sup>2</sup>]]
Ym2 [[Square metre|Ym<sup>2</sup>]]
zm2 [[Square metre|zm<sup>2</sup>]]
Zm2 [[Square metre|Zm<sup>2</sup>]]
gal [[Gallon|gal]]
Gal [[Gal (unit)|Gal]]
uGal [[Gal (unit)|µGal]]
µGal [[Gal (unit)|µGal]]
mGal [[Gal (unit)|mGal]]
b [[Barn (unit)|b]] SI
ab [[Barn (unit)|b]] SI
cb [[Barn (unit)|b]] SI
dab [[Barn (unit)|b]] SI
db [[Barn (unit)|b]] SI
Eb [[Barn (unit)|b]] SI
fb [[Barn (unit)|b]] SI
Gb [[Barn (unit)|b]] SI
hb [[Barn (unit)|b]] SI
kb [[Barn (unit)|b]] SI
mb [[Barn (unit)|b]] SI
µb [[Barn (unit)|b]] SI
ub [[Barn (unit)|b]] SI
Mb [[Barn (unit)|b]] SI
nb [[Barn (unit)|b]] SI
pb [[Barn (unit)|b]] SI
Pb [[Barn (unit)|b]] SI
Tb [[Barn (unit)|b]] SI
Yb [[Barn (unit)|b]] SI
yb [[Barn (unit)|b]] SI
Zb [[Barn (unit)|b]] SI
zb [[Barn (unit)|b]] SI
== Velocity and acceleration ==
m.s-2 [[Metre per second squared|m⋅s<sup>−2</sup>]]
m/s2 [[Metre per second squared|m/s<sup>2</sup>]]
m.s-1 [[Metre per second|m⋅s<sup>−1</sup>]]
m/s [[Metre per second|m/s]]
km.s-1 [[Metre per second|km⋅s<sup>−1</sup>]]
km/s [[Metre per second|km/s]]
== Mass and energy ==
lbm [[Pound (mass)|<span title="pound-mass">lb<sub>m</sub></span>]]
uJ [[Joule|µJ]]
J.s [[Joule-second|J⋅s]]
kWh [[Kilowatt hour|kWh]]
kW.h [[Kilowatt hour|kW⋅h]]
J/C [[Volt|J/C]]
J/kg [[Joule|J/kg]]
Da [[Dalton (unit)|Da]] SI
EDa [[Dalton (unit)|Da]] SI
PDa [[Dalton (unit)|Da]] SI
TDa [[Dalton (unit)|Da]] SI
GDa [[Dalton (unit)|Da]] SI
MDa [[Dalton (unit)|Da]] SI
kDa [[Dalton (unit)|Da]] SI
mDa [[Dalton (unit)|Da]] SI
uDa [[Dalton (unit)|Da]] SI
μDa [[Dalton (unit)|Da]] SI
nDa [[Dalton (unit)|Da]] SI
pDa [[Dalton (unit)|Da]] SI
fDa [[Dalton (unit)|Da]] SI
aDa [[Dalton (unit)|Da]] SI
g [[Gram|g]] SI
ag [[Attogram|g]] SI
cg [[Centigram|g]] SI
dag [[Gram|g]] SI
dg [[Decigram|g]] SI
Eg [[Exagram|g]] SI
fg [[Femtogram|g]] SI
Gg [[Gigagram|g]] SI
hg [[Kilogram#SI multiples|g]] SI
kg [[Kilogram|g]] SI
mcg [[Microgram|g]] SI
Mg [[Megagram|g]] SI
mg [[Milligram|g]] SI
ug [[Microgram|g]] SI
µg [[Microgram|g]] SI
ng [[Nanogram|g]] SI
Pg [[Petagram|g]] SI
pg [[Picogram|g]] SI
Tg [[Tonne|g]] SI
yg [[Yoctogram|g]] SI
Yg [[Yottagram|g]] SI
zg [[Zeptogram|g]] SI
Zg [[Zettagram|g]] SI
== Pressure and density ==
psi [[Pounds per square inch|psi]]
g.cm-3 [[Gram per cubic centimetre|g⋅cm<sup>−3</sup>]]
g/cm3 [[Gram per cubic centimetre|g/cm<sup>3</sup>]]
kg.m-3 [[Kilogram per cubic metre|kg⋅m<sup>−3</sup>]]
kg/m3 [[Kilogram per cubic metre|kg/m<sup>3</sup>]]
kg/cm3 [[Density#Formula and common units|kg/cm<sup>3</sup>]]
g/L [[Gram per litre|g/L]]
g/l [[Gram per litre|g/l]]
mcg/dL [[Gram per litre|µg/dL]]
mcg/dl [[Gram per litre|µg/dl]]
mg/mL [[Gram per litre|mg/mL]]
mg/ml [[Gram per litre|mg/ml]]
ug/dL [[Gram per litre|µg/dL]]
ug/dl [[Gram per litre|µg/dl]]
μg/dL [[Gram per litre|μg/dL]]
μg/dl [[Gram per litre|μg/dl]]
mg.L-1 [[Gram per litre|<abbr title="milligrams per liter">mg/L</abbr>]]
mg/L [[Gram per litre|<abbr title="milligrams per liter">mg/L</abbr>]]
mg.l-1 [[Gram per litre|<abbr title="milligrams per liter">mg/l</abbr>]]
mg/l [[Gram per litre|<abbr title="milligrams per liter">mg/l</abbr>]]
== Fracture toughness ==
MPa.m.5 [[Fracture toughness|MPa⋅m<sup>1/2</sup>]]
kPa.m.5 [[Fracture toughness|kPa⋅m<sup>1/2</sup>]]
Pa.m.5 [[Fracture toughness|Pa⋅m<sup>1/2</sup>]]
== Temperature ==
degC °C ALIAS
degF °F ALIAS
degR °R ALIAS
K [[Kelvin|K]] SI
YK [[Yottakelvin|K]] SI
ZK [[Zettakelvin|K]] SI
EK [[Kelvin|K]] SI
PK [[Petakelvin|K]] SI
TK [[Terakelvin|K]] SI
GK [[Gigakelvin|K]] SI
MK [[Megakelvin|K]] SI
kK [[Kilokelvin|K]] SI
hK [[Hectokelvin|K]] SI
daK [[Decakelvin|K]] SI
dK [[Decikelvin|K]] SI
cK [[Centikelvin|K]] SI
mK [[Millikelvin|K]] SI
µK [[Microkelvin|K]] SI
uK [[Microkelvin|K]] SI
nK [[Nanokelvin|K]] SI
pK [[Picokelvin|K]] SI
fK [[Femtokelvin|K]] SI
aK [[Attokelvin|K]] SI
zK [[Zeptokelvin|K]] SI
yK [[Yoctokelvin|K]] SI
== Electromagnetism ==
Wb [[Weber (unit)|Wb]]
N.A-2 [[Permeability (electromagnetism)|N⋅A<sup>−2</sup>]]
H.m-1 [[Permeability (electromagnetism)|H⋅m<sup>−1</sup>]]
V.m-1 [[Electric field|V⋅m<sup>−1</sup>]]
V/m [[Electric field|V/m]]
C [[Coulomb|C]] SI
YC [[Coulomb|C]] SI
ZC [[Coulomb|C]] SI
EC [[Coulomb|C]] SI
PC [[Coulomb|C]] SI
TC [[Coulomb|C]] SI
GC [[Coulomb|C]] SI
MC [[Coulomb|C]] SI
kC [[Coulomb|C]] SI
hC [[Coulomb|C]] SI
daC [[Coulomb|C]] SI
dC [[Coulomb|C]] SI
cC [[Coulomb|C]] SI
mC [[Coulomb|C]] SI
µC [[Coulomb|C]] SI
uC [[Coulomb|C]] SI
nC [[Coulomb|C]] SI
pC [[Coulomb|C]] SI
fC [[Coulomb|C]] SI
aC [[Coulomb|C]] SI
zC [[Coulomb|C]] SI
yC [[Coulomb|C]] SI
F [[Farad|F]] SI
YF [[Farad|F]] SI
ZF [[Farad|F]] SI
EF [[Farad|F]] SI
PF [[Farad|F]] SI
TF [[Farad|F]] SI
GF [[Farad|F]] SI
MF [[Farad|F]] SI
kF [[Farad|F]] SI
hF [[Farad|F]] SI
daF [[Farad|F]] SI
dF [[Farad|F]] SI
cF [[Farad|F]] SI
mF [[Farad|F]] SI
µF [[Farad|F]] SI
uF [[Farad|F]] SI
nF [[Farad|F]] SI
pF [[Farad|F]] SI
fF [[Farad|F]] SI
aF [[Farad|F]] SI
zF [[Farad|F]] SI
yF [[Farad|F]] SI
H [[Henry (unit)|H]] SI
YH [[Henry (unit)|H]] SI
ZH [[Henry (unit)|H]] SI
EH [[Henry (unit)|H]] SI
PH [[Henry (unit)|H]] SI
TH [[Henry (unit)|H]] SI
GH [[Henry (unit)|H]] SI
MH [[Henry (unit)|H]] SI
kH [[Henry (unit)|H]] SI
hH [[Henry (unit)|H]] SI
daH [[Henry (unit)|H]] SI
dH [[Henry (unit)|H]] SI
cH [[Henry (unit)|H]] SI
mH [[Henry (unit)|H]] SI
µH [[Henry (unit)|H]] SI
uH [[Henry (unit)|H]] SI
nH [[Henry (unit)|H]] SI
pH [[Henry (unit)|H]] SI
fH [[Henry (unit)|H]] SI
aH [[Henry (unit)|H]] SI
zH [[Henry (unit)|H]] SI
yH [[Henry (unit)|H]] SI
A [[Ampere|A]] SI
YA [[Ampere|A]] SI
ZA [[Ampere|A]] SI
EA [[Ampere|A]] SI
PA [[Ampere|A]] SI
TA [[Ampere|A]] SI
GA [[Ampere|A]] SI
MA [[Ampere|A]] SI
kA [[Ampere|A]] SI
hA [[Ampere|A]] SI
daA [[Ampere|A]] SI
dA [[Ampere|A]] SI
cA [[Ampere|A]] SI
mA [[Ampere|A]] SI
µA [[Ampere|A]] SI
uA [[Ampere|A]] SI
nA [[Ampere|A]] SI
pA [[Ampere|A]] SI
fA [[Ampere|A]] SI
aA [[Ampere|A]] SI
zA [[Ampere|A]] SI
yA [[Ampere|A]] SI
V [[Volt|V]] SI
YV [[Volt|V]] SI
ZV [[Volt|V]] SI
EV [[Volt|V]] SI
PV [[Volt|V]] SI
TV [[Volt|V]] SI
GV [[Volt|V]] SI
MV [[Volt|V]] SI
kV [[Volt|V]] SI
hV [[Volt|V]] SI
daV [[Volt|V]] SI
dV [[Volt|V]] SI
cV [[Volt|V]] SI
mV [[Volt|V]] SI
µV [[Volt|V]] SI
uV [[Volt|V]] SI
nV [[Volt|V]] SI
pV [[Volt|V]] SI
fV [[Volt|V]] SI
aV [[Volt|V]] SI
zV [[Volt|V]] SI
yV [[Volt|V]] SI
VA [[Volt-ampere|VA]] SI
YVA [[Volt-ampere|VA]] SI
ZVA [[Volt-ampere|VA]] SI
EVA [[Volt-ampere|VA]] SI
PVA [[Volt-ampere|VA]] SI
TVA [[Volt-ampere|VA]] SI
GVA [[Volt-ampere|VA]] SI
MVA [[Volt-ampere|VA]] SI
kVA [[Volt-ampere|VA]] SI
hVA [[Volt-ampere|VA]] SI
daVA [[Volt-ampere|VA]] SI
dVA [[Volt-ampere|VA]] SI
cVA [[Volt-ampere|VA]] SI
mVA [[Volt-ampere|VA]] SI
µVA [[Volt-ampere|VA]] SI
uVA [[Volt-ampere|VA]] SI
nVA [[Volt-ampere|VA]] SI
pVA [[Volt-ampere|VA]] SI
fVA [[Volt-ampere|VA]] SI
aVA [[Volt-ampere|VA]] SI
zVA [[Volt-ampere|VA]] SI
yVA [[Volt-ampere|VA]] SI
Ω [[Ohm|Ω]] SI
YΩ.m [[Electrical resistivity and conductivity#Definition|YΩ⋅m]] 1e24
ZΩ.m [[Electrical resistivity and conductivity#Definition|ZΩ⋅m]] 1e21
EΩ.m [[Electrical resistivity and conductivity#Definition|EΩ⋅m]] 1e18
PΩ.m [[Electrical resistivity and conductivity#Definition|PΩ⋅m]] 1e15
TΩ.m [[Electrical resistivity and conductivity#Definition|TΩ⋅m]] 1e12
GΩ.m [[Electrical resistivity and conductivity#Definition|GΩ⋅m]] 1e9
MΩ.m [[Electrical resistivity and conductivity#Definition|MΩ⋅m]] 1e6
kΩ.m [[Electrical resistivity and conductivity#Definition|kΩ⋅m]] 1e3
Ω.m [[Electrical resistivity and conductivity#Definition|Ω⋅m]] 1
mΩ.m [[Electrical resistivity and conductivity#Definition|mΩ⋅m]] 1e-3
µΩ.m [[Electrical resistivity and conductivity#Definition|µΩ⋅m]] 1e-6
uΩ.m [[Electrical resistivity and conductivity#Definition|µΩ⋅m]] 1e-6
nΩ.m [[Electrical resistivity and conductivity#Definition|nΩ⋅m]] 1e-9
pΩ.m [[Electrical resistivity and conductivity#Definition|pΩ⋅m]] 1e-12
fΩ.m [[Electrical resistivity and conductivity#Definition|fΩ⋅m]] 1e-15
aΩ.m [[Electrical resistivity and conductivity#Definition|aΩ⋅m]] 1e-18
zΩ.m [[Electrical resistivity and conductivity#Definition|zΩ⋅m]] 1e-21
yΩ.m [[Electrical resistivity and conductivity#Definition|yΩ⋅m]] 1e-24
R [[Rayleigh (unit)|R]] SI
G [[Gauss (unit)|G]] SI
aG [[Attogauss|G]] SI
cG [[Centigauss|G]] SI
daG [[Decagauss|G]] SI
dG [[Decigauss|G]] SI
EG [[Exagauss|G]] SI
fG [[Femtogauss|G]] SI
GG [[Gigagauss|G]] SI
hG [[Hectogauss|G]] SI
kG [[Kilogauss|G]] SI
MG [[Megagauss|G]] SI
mG [[Milligauss|G]] SI
uG [[Microgauss|G]] SI
µG [[Microgauss|G]] SI
nG [[Nanogauss|G]] SI
PG [[Petagauss|G]] SI
pG [[Picogauss|G]] SI
TG [[Teragauss|G]] SI
yG [[Yoctogauss|G]] SI
YG [[Yottagauss|G]] SI
zG [[Zeptogauss|G]] SI
ZG [[Zettagauss|G]] SI
T [[Tesla (unit)|T]] SI
aT [[Attotesla|T]] SI
cT [[Centitesla|T]] SI
daT [[Decatesla|T]] SI
dT [[Decitesla|T]] SI
ET [[Exatesla|T]] SI
fT [[Femtotesla|T]] SI
GT [[Gigatesla|T]] SI
hT [[Hectotesla|T]] SI
kT [[Kilotesla|T]] SI
MT [[Megatesla|T]] SI
mT [[Millitesla|T]] SI
uT [[Microtesla|T]] SI
µT [[Microtesla|T]] SI
nT [[Nanotesla|T]] SI
PT [[Petatesla|T]] SI
pT [[Picotesla|T]] SI
TT [[Teratesla|T]] SI
yT [[Yoctotesla|T]] SI
YT [[Yottatesla|T]] SI
zT [[Zeptotesla|T]] SI
ZT [[Zettatesla|T]] SI
== Astrophysics ==
au [[Astronomical unit|au]]
c [[Speed of light|''c'']]
ly [[Light-year|ly]]
Earth mass [[Earth mass|''M''<sub>🜨</sub>]]
Earth radius [[Earth radius|''R''<sub>🜨</sub>]]
M_Earth [[Earth mass|''M''<sub>🜨</sub>]]
R_Earth [[Earth radius|''R''<sub>🜨</sub>]]
M+ [[Earth mass|''M''<sub>🜨</sub>]]
R+ [[Earth radius|''R''<sub>🜨</sub>]]
Jupiter mass [[Jupiter mass|''M''<sub>J</sub>]]
Jupiter radius [[Jupiter radius|''R''<sub>J</sub>]]
Jy [[Jansky|Jy]]
M_Jupiter [[Jupiter mass|''M''<sub>J</sub>]]
R_Jupiter [[Jupiter radius|''R''<sub>J</sub>]]
Solar mass [[Solar mass|''M''<sub>☉</sub>]]
solar mass [[Solar mass|''M''<sub>☉</sub>]]
M_Solar [[Solar mass|''M''<sub>☉</sub>]]
M_solar [[Solar mass|''M''<sub>☉</sub>]]
R_Solar [[Solar radius|''R''<sub>☉</sub>]]
R_solar [[Solar radius|''R''<sub>☉</sub>]]
Solar radius [[Solar radius|''R''<sub>☉</sub>]]
solar radius [[Solar radius|''R''<sub>☉</sub>]]
Solar luminosity [[Solar luminosity|''L''<sub>☉</sub>]]
solar luminosity [[Solar luminosity|''L''<sub>☉</sub>]]
L_solar [[Solar luminosity|''L''<sub>☉</sub>]]
L_Solar [[Solar luminosity|''L''<sub>☉</sub>]]
Lo [[Solar luminosity|''L''<sub>☉</sub>]]
pc2 [[Parsec|pc<sup>2</sup>]]
pc3 [[Parsec|pc<sup>3</sup>]]
kpc2 [[Parsec#Parsecs and kiloparsecs|kpc<sup>2</sup>]]
kpc3 [[Parsec#Parsecs and kiloparsecs|kpc<sup>3</sup>]]
kpc [[Parsec#Parsecs and kiloparsecs|kpc]]
Mpc2 [[Parsec#Megaparsecs and gigaparsecs|Mpc<sup>2</sup>]]
Mpc3 [[Parsec#Megaparsecs and gigaparsecs|Mpc<sup>3</sup>]]
Mpc [[Parsec#Megaparsecs and gigaparsecs|Mpc]]
Gpc2 [[Parsec#Megaparsecs and gigaparsecs|Gpc<sup>2</sup>]]
Gpc3 [[Parsec#Megaparsecs and gigaparsecs|Gpc<sup>3</sup>]]
Gpc [[Parsec#Megaparsecs and gigaparsecs|Gpc]]
== Nuclear physics and chemistry ==
cm-1 [[Wavenumber|cm<sup>−1</sup>]]
u [[Unified atomic mass unit|u]]
osmol [[Osmole (unit)|osmol]]
Osm [[Osmole (unit)|Osm]]
M [[Molarity|M]]
TM [[Molarity|M]] SI
GM [[Molarity|M]] SI
MM [[Molarity|M]] SI
kM [[Molarity|M]] SI
hM [[Molarity|M]] SI
daM [[Molarity|M]] SI
dM [[Molarity|M]] SI
cM [[Molarity|M]] SI
mM [[Molarity|M]] SI
uM [[Molarity|M]] 1e-6
nM [[Molarity|M]] SI
pM [[Molarity|M]] SI
kg.mol-1 [[Molar mass|kg⋅mol<sup>−1</sup>]]
kg/mol [[Molar mass|kg/mol]]
g.mol-1 [[Molar mass|g⋅mol<sup>−1</sup>]]
g/mol [[Molar mass|g/mol]]
eV/c2 [[Electronvolt#Mass|eV/''c''<sup>2</sup>]]
keV/c2 [[Electronvolt#Mass|keV/''c''<sup>2</sup>]]
MeV/c2 [[Electronvolt#Mass|MeV/''c''<sup>2</sup>]]
GeV/c2 [[Electronvolt#Mass|GeV/''c''<sup>2</sup>]]
TeV/c2 [[Electronvolt#Mass|TeV/''c''<sup>2</sup>]]
eV [[Electronvolt|eV]]
meV [[Electronvolt|meV]]
keV [[Electronvolt|keV]]
MeV [[Electronvolt|MeV]]
GeV [[Electronvolt|GeV]]
TeV [[Electronvolt|TeV]]
mol-1 [[Avogadro constant|mol<sup>−1</sup>]]
J.mol-1 [[Joule per mole|J⋅mol<sup>−1</sup>]]
J/mol [[Joule per mole|J/mol]]
kJ.mol-1 [[Joule per mole|kJ⋅mol<sup>−1</sup>]]
kJ/mol [[Joule per mole|kJ/mol]]
MJ.mol-1 [[Joule per mole|MJ⋅mol<sup>−1</sup>]]
MJ/mol [[Joule per mole|MJ/mol]]
GJ.mol-1 [[Joule per mole|GJ⋅mol<sup>−1</sup>]]
GJ/mol [[Joule per mole|GJ/mol]]
TJ.mol-1 [[Joule per mole|TJ⋅mol<sup>−1</sup>]]
TJ/mol [[Joule per mole|TJ/mol]]
μB [[Bohr magneton|''μ''<sub>B</sub>]]
== Numbers and phrases ==
pp [[Page (paper)|pp]]
ppb [[Parts per billion|ppb]] 1e-9
ppm [[Parts per million|ppm]] 1e-6
billiard [[Orders of magnitude (numbers)#1015|billiard]] 1e15
billion [[1,000,000,000|billion]] 1e9
billionth [[1,000,000,000|billionth]] 1e-9
billionths [[1,000,000,000|billionths]] 1e-9
decilliard [[Orders of magnitude (numbers)#1063|decilliard]] 1e63
decillion [[Orders of magnitude (numbers)#1033|decillion]] 1e33
decillionth [[Orders of magnitude (numbers)#1033|decillionth]] 1e-33
decillionths [[Orders of magnitude (numbers)#1033|decillionths]] 1e-33
milliard [[1,000,000,000|milliard]] 1e9
million [[Million|million]] 1e6
millionth [[Million|millionth]] 1e-6
millionths [[Million|millionths]] 1e-6
nonilliard [[Orders of magnitude (numbers)#1057|nonilliard]] 1e57
nonillion [[Orders of magnitude (numbers)#1030|nonillion]] 1e30
nonillionth [[Orders of magnitude (numbers)#1030|nonillionth]] 1e-30
nonillionths [[Orders of magnitude (numbers)#1030|nonillionths]] 1e-30
octilliard [[Orders of magnitude (numbers)#1051|octilliard]] 1e51
octillion [[Orders of magnitude (numbers)#1027|octillion]] 1e27
octillionth [[Orders of magnitude (numbers)#1027|octillionth]] 1e-27
octillionths [[Orders of magnitude (numbers)#1027|octillionths]] 1e-27
quadrilliard [[Orders of magnitude (numbers)#1027|quadrilliard]] 1e27
quadrillion [[Orders of magnitude (numbers)#1015|quadrillion]] 1e15
quadrillionth [[Orders of magnitude (numbers)#1015|quadrillionth]] 1e-15
quadrillionths [[Orders of magnitude (numbers)#1015|quadrillionths]] 1e-15
quintilliard [[Orders of magnitude (numbers)#1033|quintilliard]] 1e33
quintillion [[Orders of magnitude (numbers)#1018|quintillion]] 1e18
quintillionth [[Orders of magnitude (numbers)#1018|quintillionth]] 1e-18
quintillionths [[Orders of magnitude (numbers)#1018|quintillionths]] 1e-18
septilliard [[Orders of magnitude (numbers)#1045|septilliard]] 1e45
septillion [[Orders of magnitude (numbers)#1024|septillion]] 1e24
septillionth [[Orders of magnitude (numbers)#1024|septillionth]] 1e-24
septillionths [[Orders of magnitude (numbers)#1024|septillionths]] 1e-24
sextilliard [[Orders of magnitude (numbers)#1039|sextilliard]] 1e39
sextillion [[Orders of magnitude (numbers)#1021|sextillion]] 1e21
sextillionth [[Orders of magnitude (numbers)#1021|sextillionth]] 1e-21
sextillionths [[Orders of magnitude (numbers)#1021|sextillionths]] 1e-21
trilliard [[Orders of magnitude (numbers)#1021|trilliard]] 1e21
trillion [[Orders of magnitude (numbers)#1012|trillion]] 1e12
trillionth [[Orders of magnitude (numbers)#1012|trillionth]] 1e-12
trillionths [[Orders of magnitude (numbers)#1012|trillionths]] 1e-12
== Angles ==
% % Percent ANGLE 0.01
percent % Percent ANGLE 0.01
per cent % Percent ANGLE 0.01
‰ ‰ Per mil ANGLE 1e-3
per mil ‰ Per mil ANGLE 1e-3
per mill ‰ Per mil ANGLE 1e-3
per mille ‰ Per mil ANGLE 1e-3
permil ‰ Per mil ANGLE 1e-3
permill ‰ Per mil ANGLE 1e-3
permille ‰ Per mil ANGLE 1e-3
° ° Degree (angle) ANGLE pi/180
deg ° Degree (angle) ANGLE pi/180
degree ° Degree (angle) NOSPACE pi/180 -- for a degree symbol that does not repeat
' ′ Minute of arc ANGLE pi/10800
′ ′ Minute of arc ANGLE pi/10800
arcmin ′ Minute of arc ANGLE pi/10800
arcminute ′ Minute of arc ANGLE pi/10800
" ″ Second of arc ANGLE pi/648000
″ ″ Second of arc ANGLE pi/648000
arcsec ″ Second of arc ANGLE pi/648000
arcsecond ″ Second of arc ANGLE pi/648000
mas [[Milliarcsecond|mas]] pi/648000000
]=]
-- If val has "|long scale=on" the following definitions are used
-- (then, if not found here, the normal definitions are used).
-- Unit code [[Link|Symbol]] Flags/Scale
local builtin_units_long_scale = [=[
== Long scale numbers and phrases ==
billion [[Orders of magnitude (numbers)#1012|billion]] 1e12
billionth [[Orders of magnitude (numbers)#1012|billionth]] 1e-12
billionths [[Orders of magnitude (numbers)#1012|billionths]] 1e-12
decillion [[Orders of magnitude (numbers)#1060|decillion]] 1e60
decillionth [[Orders of magnitude (numbers)#1060|decillionth]] 1e-60
decillionths [[Orders of magnitude (numbers)#1060|decillionths]] 1e-60
nonillion [[Orders of magnitude (numbers)#1054|nonillion]] 1e54
nonillionth [[Orders of magnitude (numbers)#1054|nonillionth]] 1e-54
nonillionths [[Orders of magnitude (numbers)#1054|nonillionths]] 1e-54
octillion [[Orders of magnitude (numbers)#1048|octillion]] 1e48
octillionth [[Orders of magnitude (numbers)#1048|octillionth]] 1e-48
octillionths [[Orders of magnitude (numbers)#1048|octillionths]] 1e-48
quadrillion [[Orders of magnitude (numbers)#1024|quadrillion]] 1e24
quadrillionth [[Orders of magnitude (numbers)#1024|quadrillionth]] 1e-24
quadrillionths [[Orders of magnitude (numbers)#1024|quadrillionths]] 1e-24
quintillion [[Orders of magnitude (numbers)#1030|quintillion]] 1e30
quintillionth [[Orders of magnitude (numbers)#1030|quintillionth]] 1e-30
quintillionths [[Orders of magnitude (numbers)#1030|quintillionths]] 1e-30
septillion [[Orders of magnitude (numbers)#1042|septillion]] 1e42
septillionth [[Orders of magnitude (numbers)#1042|septillionth]] 1e-42
septillionths [[Orders of magnitude (numbers)#1042|septillionths]] 1e-42
sextillion [[Orders of magnitude (numbers)#1036|sextillion]] 1e36
sextillionth [[Orders of magnitude (numbers)#1036|sextillionth]] 1e-36
sextillionths [[Orders of magnitude (numbers)#1036|sextillionths]] 1e-36
trillion [[Orders of magnitude (numbers)#1018|trillion]] 1e18
trillionth [[Orders of magnitude (numbers)#1018|trillionth]] 1e-18
trillionths [[Orders of magnitude (numbers)#1018|trillionths]] 1e-18
]=]
return { builtin_units = builtin_units, builtin_units_long_scale = builtin_units_long_scale }
2307ae0d1410328f2d5ace7ab494855c5cb9c9e9
Module:Convert/extra
828
725
1113
2025-07-02T08:58:47Z
wikipedia>Johnuniq
0
try "per-km2" workaround per [[Template talk:Convert#per km²]]
Scribunto
text/plain
-- Extra conversion data used by Module:Convert.
--
-- [[Module:Convert/data]] defines all units and is transcluded in all pages
-- where [[Module:Convert]] is used. Testing new units by editing that module
-- would invalidate the cache for all affected pages.
--
-- For quick changes and experiments with new units, this module can be edited.
-- Since this module is transcluded in only a small number of pages, changes
-- should cause little server overhead and should propagate quickly.
--
-- If a unit is defined in the data module, any definition here is ignored,
-- so defining the same unit in both modules is not an error.
-- A unit defined here can refer to units that are also defined here, and
-- can refer to units defined in the data module.
--
-- Periodically, those extra units that are wanted permanently can be removed
-- from here after being added to [[Module:Convert/data]].
local extra_units = {
["bit"] = {
_name1 = "bit",
_symbol = "bit",
utype = "information",
scale = 0.125,
prefixes = 1,
default = "B",
link = "Bit",
},
["per-km2"] = {
name1 = "per square kilometre",
name1_us = "per square kilometer",
name2 = "per square kilometre",
name2_us = "per square kilometer",
symbol = "per km<sup>2</sup>",
utype = "per unit area",
scale = 1e-6,
default = "/sqmi",
link = "Square kilometre",
},
}
return { extra_units = extra_units }
55a4ac716545a8687a16e661345c64dca7597848
Category:Dual Wields
14
469
702
2025-07-13T14:44:26Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
[[Category:Weapons]]
febdf29cf9dcbef034e184720fe19a5ac5f353d8
Category:Weapons
14
468
700
2025-07-13T14:45:01Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
'''Weapons''' are equipment the player can use to damage monsters and defend themselves.
98e971be059993e01129097dd2602abe573ed443
Sharp
0
526
812
2025-07-13T14:49:25Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
'''Sharp''' is a type of damage in {{BFF}}.
791f7c953da43e2ac6ebe338f36d863e32d3ac49
Module:Math
828
534
828
2025-07-13T14:59:23Z
Sharparam
284703
Initial page copied from [[wikipedia:Module:Math]]
Scribunto
text/plain
--[[
This module provides a number of basic mathematical operations.
]]
local yesno, getArgs -- lazily initialized
local p = {} -- Holds functions to be returned from #invoke, and functions to make available to other Lua modules.
local wrap = {} -- Holds wrapper functions that process arguments from #invoke. These act as intemediary between functions meant for #invoke and functions meant for Lua.
--[[
Helper functions used to avoid redundant code.
]]
local function err(msg)
-- Generates wikitext error messages.
return mw.ustring.format('<strong class="error">Formatting error: %s</strong>', msg)
end
local function unpackNumberArgs(args)
-- Returns an unpacked list of arguments specified with numerical keys.
local ret = {}
for k, v in pairs(args) do
if type(k) == 'number' then
table.insert(ret, v)
end
end
return unpack(ret)
end
local function makeArgArray(...)
-- Makes an array of arguments from a list of arguments that might include nils.
local args = {...} -- Table of arguments. It might contain nils or non-number values, so we can't use ipairs.
local nums = {} -- Stores the numbers of valid numerical arguments.
local ret = {}
for k, v in pairs(args) do
v = p._cleanNumber(v)
if v then
nums[#nums + 1] = k
args[k] = v
end
end
table.sort(nums)
for i, num in ipairs(nums) do
ret[#ret + 1] = args[num]
end
return ret
end
local function fold(func, ...)
-- Use a function on all supplied arguments, and return the result. The function must accept two numbers as parameters,
-- and must return a number as an output. This number is then supplied as input to the next function call.
local vals = makeArgArray(...)
local count = #vals -- The number of valid arguments
if count == 0 then return
-- Exit if we have no valid args, otherwise removing the first arg would cause an error.
nil, 0
end
local ret = table.remove(vals, 1)
for _, val in ipairs(vals) do
ret = func(ret, val)
end
return ret, count
end
--[[
Fold arguments by selectively choosing values (func should return when to choose the current "dominant" value).
]]
local function binary_fold(func, ...)
local value = fold((function(a, b) if func(a, b) then return a else return b end end), ...)
return value
end
--[[
random
Generate a random number
Usage:
{{#invoke: Math | random }}
{{#invoke: Math | random | maximum value }}
{{#invoke: Math | random | minimum value | maximum value }}
]]
function wrap.random(args)
local first = p._cleanNumber(args[1])
local second = p._cleanNumber(args[2])
return p._random(first, second)
end
function p._random(first, second)
math.randomseed(mw.site.stats.edits + mw.site.stats.pages + os.time() + math.floor(os.clock() * 1000000000))
-- math.random will throw an error if given an explicit nil parameter, so we need to use if statements to check the params.
if first and second then
if first <= second then -- math.random doesn't allow the first number to be greater than the second.
return math.random(first, second)
end
elseif first then
return math.random(first)
else
return math.random()
end
end
--[[
order
Determine order of magnitude of a number
Usage:
{{#invoke: Math | order | value }}
]]
function wrap.order(args)
local input_string = (args[1] or args.x or '0');
local input_number = p._cleanNumber(input_string);
if input_number == nil then
return err('order of magnitude input appears non-numeric')
else
return p._order(input_number)
end
end
function p._order(x)
if x == 0 then return 0 end
return math.floor(math.log10(math.abs(x)))
end
--[[
precision
Detemines the precision of a number using the string representation
Usage:
{{ #invoke: Math | precision | value }}
]]
function wrap.precision(args)
local input_string = (args[1] or args.x or '0');
local trap_fraction = args.check_fraction;
local input_number;
if not yesno then
yesno = require('Module:Yesno')
end
if yesno(trap_fraction, true) then -- Returns true for all input except nil, false, "no", "n", "0" and a few others. See [[Module:Yesno]].
local pos = string.find(input_string, '/', 1, true);
if pos ~= nil then
if string.find(input_string, '/', pos + 1, true) == nil then
local denominator = string.sub(input_string, pos+1, -1);
local denom_value = tonumber(denominator);
if denom_value ~= nil then
return math.log10(denom_value);
end
end
end
end
input_number, input_string = p._cleanNumber(input_string);
if input_string == nil then
return err('precision input appears non-numeric')
else
return p._precision(input_string)
end
end
function p._precision(x)
if type(x) == 'number' then
x = tostring(x)
end
x = string.upper(x)
local decimal = x:find('%.')
local exponent_pos = x:find('E')
local result = 0;
if exponent_pos ~= nil then
local exponent = string.sub(x, exponent_pos + 1)
x = string.sub(x, 1, exponent_pos - 1)
result = result - tonumber(exponent)
end
if decimal ~= nil then
result = result + string.len(x) - decimal
return result
end
local pos = string.len(x);
while x:byte(pos) == string.byte('0') do
pos = pos - 1
result = result - 1
if pos <= 0 then
return 0
end
end
return result
end
--[[
max
Finds the maximum argument
Usage:
{{#invoke:Math| max | value1 | value2 | ... }}
Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.max(args)
return p._max(unpackNumberArgs(args))
end
function p._max(...)
local max_value = binary_fold((function(a, b) return a > b end), ...)
if max_value then
return max_value
end
end
--[[
median
Find the median of set of numbers
Usage:
{{#invoke:Math | median | number1 | number2 | ...}}
OR
{{#invoke:Math | median }}
]]
function wrap.median(args)
return p._median(unpackNumberArgs(args))
end
function p._median(...)
local vals = makeArgArray(...)
local count = #vals
table.sort(vals)
if count == 0 then
return 0
end
if p._mod(count, 2) == 0 then
return (vals[count/2] + vals[count/2+1])/2
else
return vals[math.ceil(count/2)]
end
end
--[[
min
Finds the minimum argument
Usage:
{{#invoke:Math| min | value1 | value2 | ... }}
OR
{{#invoke:Math| min }}
When used with no arguments, it takes its input from the parent
frame. Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.min(args)
return p._min(unpackNumberArgs(args))
end
function p._min(...)
local min_value = binary_fold((function(a, b) return a < b end), ...)
if min_value then
return min_value
end
end
--[[
sum
Finds the sum
Usage:
{{#invoke:Math| sum | value1 | value2 | ... }}
OR
{{#invoke:Math| sum }}
Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.sum(args)
return p._sum(unpackNumberArgs(args))
end
function p._sum(...)
local sums, count = fold((function(a, b) return a + b end), ...)
if not sums then
return 0
else
return sums
end
end
--[[
average
Finds the average
Usage:
{{#invoke:Math| average | value1 | value2 | ... }}
OR
{{#invoke:Math| average }}
Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.average(args)
return p._average(unpackNumberArgs(args))
end
function p._average(...)
local sum, count = fold((function(a, b) return a + b end), ...)
if not sum then
return 0
else
return sum / count
end
end
--[[
round
Rounds a number to specified precision
Usage:
{{#invoke:Math | round | value | precision }}
--]]
function wrap.round(args)
local value = p._cleanNumber(args[1] or args.value or 0)
local precision = p._cleanNumber(args[2] or args.precision or 0)
if value == nil or precision == nil then
return err('round input appears non-numeric')
else
return p._round(value, precision)
end
end
function p._round(value, precision)
local rescale = math.pow(10, precision or 0);
return math.floor(value * rescale + 0.5) / rescale;
end
--[[
log10
returns the log (base 10) of a number
Usage:
{{#invoke:Math | log10 | x }}
]]
function wrap.log10(args)
return math.log10(args[1])
end
--[[
mod
Implements the modulo operator
Usage:
{{#invoke:Math | mod | x | y }}
--]]
function wrap.mod(args)
local x = p._cleanNumber(args[1])
local y = p._cleanNumber(args[2])
if not x then
return err('first argument to mod appears non-numeric')
elseif not y then
return err('second argument to mod appears non-numeric')
else
return p._mod(x, y)
end
end
function p._mod(x, y)
local ret = x % y
if not (0 <= ret and ret < y) then
ret = 0
end
return ret
end
--[[
gcd
Calculates the greatest common divisor of multiple numbers
Usage:
{{#invoke:Math | gcd | value 1 | value 2 | value 3 | ... }}
--]]
function wrap.gcd(args)
return p._gcd(unpackNumberArgs(args))
end
function p._gcd(...)
local function findGcd(a, b)
local r = b
local oldr = a
while r ~= 0 do
local quotient = math.floor(oldr / r)
oldr, r = r, oldr - quotient * r
end
if oldr < 0 then
oldr = oldr * -1
end
return oldr
end
local result, count = fold(findGcd, ...)
return result
end
--[[
precision_format
Rounds a number to the specified precision and formats according to rules
originally used for {{template:Rnd}}. Output is a string.
Usage:
{{#invoke: Math | precision_format | number | precision }}
]]
function wrap.precision_format(args)
local value_string = args[1] or 0
local precision = args[2] or 0
return p._precision_format(value_string, precision)
end
function p._precision_format(value_string, precision)
-- For access to Mediawiki built-in formatter.
local lang = mw.getContentLanguage();
local value
value, value_string = p._cleanNumber(value_string)
precision = p._cleanNumber(precision)
-- Check for non-numeric input
if value == nil or precision == nil then
return err('invalid input when rounding')
end
local current_precision = p._precision(value)
local order = p._order(value)
-- Due to round-off effects it is neccesary to limit the returned precision under
-- some circumstances because the terminal digits will be inaccurately reported.
if order + precision >= 14 then
if order + p._precision(value_string) >= 14 then
precision = 13 - order;
end
end
-- If rounding off, truncate extra digits
if precision < current_precision then
value = p._round(value, precision)
current_precision = p._precision(value)
end
local formatted_num = lang:formatNum(math.abs(value))
local sign
-- Use proper unary minus sign rather than ASCII default
if value < 0 then
sign = '−'
else
sign = ''
end
-- Handle cases requiring scientific notation
if string.find(formatted_num, 'E', 1, true) ~= nil or math.abs(order) >= 9 then
value = value * math.pow(10, -order)
current_precision = current_precision + order
precision = precision + order
formatted_num = lang:formatNum(math.abs(value))
else
order = 0;
end
formatted_num = sign .. formatted_num
-- Pad with zeros, if needed
if current_precision < precision then
local padding
if current_precision <= 0 then
if precision > 0 then
local zero_sep = lang:formatNum(1.1)
formatted_num = formatted_num .. zero_sep:sub(2,2)
padding = precision
if padding > 20 then
padding = 20
end
formatted_num = formatted_num .. string.rep('0', padding)
end
else
padding = precision - current_precision
if padding > 20 then
padding = 20
end
formatted_num = formatted_num .. string.rep('0', padding)
end
end
-- Add exponential notation, if necessary.
if order ~= 0 then
-- Use proper unary minus sign rather than ASCII default
if order < 0 then
order = '−' .. lang:formatNum(math.abs(order))
else
order = lang:formatNum(order)
end
formatted_num = formatted_num .. '<span style="margin:0 .15em 0 .25em">×</span>10<sup>' .. order .. '</sup>'
end
return formatted_num
end
--[[
divide
Implements the division operator
Usage:
{{#invoke:Math | divide | x | y | round= | precision= }}
--]]
function wrap.divide(args)
local x = args[1]
local y = args[2]
local round = args.round
local precision = args.precision
if not yesno then
yesno = require('Module:Yesno')
end
return p._divide(x, y, yesno(round), precision)
end
function p._divide(x, y, round, precision)
if y == nil or y == "" then
return err("Empty divisor")
elseif not tonumber(y) then
if type(y) == 'string' and string.sub(y, 1, 1) == '<' then
return y
else
return err("Not a number: " .. y)
end
elseif x == nil or x == "" then
return err("Empty dividend")
elseif not tonumber(x) then
if type(x) == 'string' and string.sub(x, 1, 1) == '<' then
return x
else
return err("Not a number: " .. x)
end
else
local z = x / y
if round then
return p._round(z, 0)
elseif precision then
return p._round(z, precision)
else
return z
end
end
end
--[[
Helper function that interprets the input numerically. If the
input does not appear to be a number, attempts evaluating it as
a parser functions expression.
]]
function p._cleanNumber(number_string)
if type(number_string) == 'number' then
-- We were passed a number, so we don't need to do any processing.
return number_string, tostring(number_string)
elseif type(number_string) ~= 'string' or not number_string:find('%S') then
-- We were passed a non-string or a blank string, so exit.
return nil, nil;
end
-- Attempt basic conversion
local number = tonumber(number_string)
-- If failed, attempt to evaluate input as an expression
if number == nil then
local success, result = pcall(mw.ext.ParserFunctions.expr, number_string)
if success then
number = tonumber(result)
number_string = tostring(number)
else
number = nil
number_string = nil
end
else
number_string = number_string:match("^%s*(.-)%s*$") -- String is valid but may contain padding, clean it.
number_string = number_string:match("^%+(.*)$") or number_string -- Trim any leading + signs.
if number_string:find('^%-?0[xX]') then
-- Number is using 0xnnn notation to indicate base 16; use the number that Lua detected instead.
number_string = tostring(number)
end
end
return number, number_string
end
--[[
Wrapper function that does basic argument processing. This ensures that all functions from #invoke can use either the current
frame or the parent frame, and it also trims whitespace for all arguments and removes blank arguments.
]]
local mt = { __index = function(t, k)
return function(frame)
if not getArgs then
getArgs = require('Module:Arguments').getArgs
end
return wrap[k](getArgs(frame)) -- Argument processing is left to Module:Arguments. Whitespace is trimmed and blank arguments are removed.
end
end }
return setmetatable(p, mt)
2bbe734d898299f65412963a3c1782e9fcc4d9ca
Template:Average
10
531
822
2025-07-13T15:05:57Z
Sharparam
284703
Initial page copied from [[wikipedia:Template:Average]]
wikitext
text/x-wiki
<includeonly>{{#if:{{{round|}}}|{{formatnum:{{round|{{#invoke:math|average}}|{{{round|}}}}}|R}}|{{#invoke:math|average}}}}</includeonly><noinclude>{{doc}}</noinclude>
b37093608b62a3faf722c64135fc79c4498e3d5b
Template:Tooltip/styles.css
10
530
820
2025-07-13T16:45:58Z
Sharparam
284703
Remove protection template
sanitized-css
text/css
.tooltip-dotted {
border-bottom: 1px dotted;
}
.tooltip-help {
cursor: help;
}
af2f58c266b5958cf73537f523615e9783db80ff
Template:Abbr/doc
10
533
826
2025-07-13T17:12:28Z
Sharparam
284703
wikitext
text/x-wiki
== Examples ==
=== [[Template:Tooltip]] ===
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text|tooltip title}}</syntaxhighlight> → {{Tooltip|text|tooltip title}}
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text "with" quotes|tooltip "with" quotes}}</syntaxhighlight> → {{Tooltip|text "with" quotes|tooltip "with" quotes}}
7e8e0dc4e38c09167b11915c2ddced76bbfe4ae4
Template:Tooltip
10
529
818
2025-07-13T17:13:16Z
Sharparam
284703
Fix quote handling
wikitext
text/x-wiki
<templatestyles src="Template:Tooltip/styles.css" /><includeonly><span class="tooltip tooltip-dotted" title="{{#replace:{{{2}}}|"|"}}">{{{1}}}</span></includeonly><noinclude>
{{Documentation|Template:Abbr/doc}}
</noinclude>
02939f9a947fe3904add1355d50d42b05211f8b9
Template:DamageRange/doc
10
528
816
2025-07-13T17:53:55Z
Sharparam
284703
Add example with decimals
wikitext
text/x-wiki
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|10|20}}</syntaxhighlight> → {{DamageRange|10|20}}
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|1|2}}</syntaxhighlight> → {{DamageRange|1|2}}
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|69|75|type=sharp}}</syntaxhighlight> → {{DamageRange|69|75|type=sharp}}
a5a6c8376c27ec92e876a4bf84571a621dfedbac
Template:Navbox/Items
10
285
311
2025-07-13T19:43:24Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = Items
| group1 = Weapons
| list1 = {{Navbox/Weapons|child}}
}}
cedb0068e5810aa53fc1e276616ba855068c2e86
Template:Infobox/Ability/doc
10
460
684
2025-07-13T21:55:40Z
Sharparam
284703
wikitext
text/x-wiki
== Example ==
{{Infobox/Ability
|image=SuperTux star-1.png
|title=Shoot Star
|Description=Shoots a star.
|Cost=50
|Cooldown=12
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Ability
|image=SuperTux star-1.png
|title=Shoot Star
|Description=Shoots a star.
|Cost=50
|Cooldown=12
}}
</syntaxhighlight>
c5af8361e58c9662fafe1e9ae1dfbc09ff0dedf9
Module:Track listing/configuration
828
409
578
2025-07-15T00:30:16Z
Sharparam
284703
Initial page
Scribunto
text/plain
return {
show_warnings = false,
input_error_category = 'Track listings with input errors',
collapsed_parameter_category = 'Track listings that use the collapsed parameter ',
deprecated_parameter_category = 'Track listings with deprecated parameters',
track_field_names = {
number = true,
title = true,
note = true,
length = true,
lyrics = true,
music = true,
writer = true,
extra = true,
},
track_listing_field_names = {
width = true,
headline = true,
all_writing = true,
all_lyrics = true,
all_music = true,
extra_column = true,
total_length = true,
title_width = true,
writing_width = true,
lyrics_width = true,
music_width = true,
extra_width = true,
category = true,
},
deprecated_track_listing_field_names = {
writing_credits = true,
lyrics_credits = true,
music_credits = true,
},
leading_0_in_hours = "Invalid time '%s' (times in format 'h:mm:ss' cannot start with zero)",
leading_0_in_minutes = "Invalid time '%s' (times in format 'mm:ss' cannot start with zero)",
not_a_time = "Invalid time '%s' (times must be in a format of 'm:ss', 'mm:ss' or 'h:mm:ss')",
more_than_60_minutes = "Invalid track length '%s' (if hours are specified, the number of minutes must be less than 60)",
more_than_60_seconds = "Invalid track length '%s' (number of seconds must be less than 60)",
tracks_written = 'All tracks are written by %s',
lyrics_written_music_composed = 'All lyrics are written by $1; all music is composed by $2',
lyrics_written = 'All lyrics are written by %s',
music_composed = 'All music is composed by %s',
track_listing_error = '<strong class="error">Track listing error: %s</strong>',
deprecated_collapsed = 'Deprecated collapsed parameter in use.',
title = 'Title',
number = 'Number',
number_abbr = 'No.',
track_listing = 'Track listing',
writer = 'Writer(s)',
lyrics = 'Lyrics',
music = 'Music',
extra = '{{{extra_column}}}',
length = 'Length',
blank_cell = ' ',
track_title = '"%s"',
untitled = 'Untitled',
note = ' (%s)',
track_id = 'track%d',
number_terminated = '%d.',
total_length = 'Total length:'
}
5fcb26176f1458c5fdb9b1ba7af4cafc73cbd05a
Module:Track listing/styles.css
828
414
588
2025-07-15T00:30:51Z
Sharparam
284703
Initial page
sanitized-css
text/css
/* {{pp|small=y}} */
.tracklist {
border-spacing: 0;
}
/* set on all rows we can set the total length row to transparent */
.tracklist tr {
background-color: var(--background-color-base, #fff);
}
.tracklist tr:nth-child(2n-1) {
background-color: var(--background-color-neutral-subtle, #f8f9fa);
}
.tracklist caption {
text-align: left;
font-weight: bold;
}
.tracklist td,
.tracklist th[scope="row"] {
vertical-align: top;
}
.tracklist th[scope="col"] {
text-align: left;
background-color: var(--background-color-neutral, #eaecf0);
}
.tracklist th.tracklist-length-header,
.tracklist th.tracklist-number-header,
.tracklist th[scope="row"],
.tracklist-length,
.tracklist-total-length td {
padding-right: 10px;
text-align: right;
}
.tracklist th[scope="row"] {
font-weight: normal;
}
.tracklist-number-header {
width: 2em;
padding-left: 10px;
}
.tracklist-length-header {
width: 4em;
}
.tracklist tr.tracklist-total-length {
background-color: transparent;
}
.tracklist .tracklist-total-length th {
padding: 0;
font-weight: bold;
}
.tracklist-total-length th > span {
float: right;
padding: 0 10px;
background-color: var(--background-color-neutral, #eaecf0);
}
.tracklist-total-length td {
background-color: var(--background-color-neutral, #eaecf0);
font-weight: bold;
padding: 0 10px 0 0;
}
bc12ba45209a6a001e4bfaed9bda7f8aff5d3334
Module:Track listing
828
408
576
2025-07-15T00:31:18Z
Sharparam
284703
Initial page
Scribunto
text/plain
local yesno = require('Module:Yesno')
local checkType = require('libraryUtil').checkType
local cfg = mw.loadData('Module:Track listing/configuration')
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
-- Add a mixin to a class.
local function addMixin(class, mixin)
for k, v in pairs(mixin) do
if k ~= 'init' then
class[k] = v
end
end
end
--------------------------------------------------------------------------------
-- Validation mixin
--------------------------------------------------------------------------------
local Validation = {}
function Validation.init(self)
self.warnings = {}
self.categories = {}
end
function Validation:addWarning(msg, category)
table.insert(self.warnings, msg)
table.insert(self.categories, category)
end
function Validation:addCategory(category)
table.insert(self.categories, category)
end
function Validation:getWarnings()
return self.warnings
end
function Validation:getCategories()
return self.categories
end
-- Validate a track length. If a track length is invalid, a warning is added.
-- A type error is raised if the length is not of type string or nil.
function Validation:validateLength(length)
checkType('validateLength', 1, length, 'string', true)
if length == nil then
-- Do nothing if no length specified
return nil
end
local hours, minutes, seconds
-- Try to match times like "1:23:45".
hours, minutes, seconds = length:match('^(%d+):(%d%d):(%d%d)$')
if hours and hours:sub(1, 1) == '0' then
-- Disallow times like "0:12:34"
self:addWarning(
string.format(cfg.leading_0_in_hours, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
if not seconds then
-- The previous attempt didn't match. Try to match times like "1:23".
minutes, seconds = length:match('^(%d?%d):(%d%d)$')
if minutes and minutes:find('^0%d$') then
-- Special case to disallow lengths like "01:23". This check has to
-- be here so that lengths like "1:01:23" are still allowed.
self:addWarning(
string.format(cfg.leading_0_in_minutes, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
end
-- Add a warning and return if we did not find a match.
if not seconds then
self:addWarning(
string.format(cfg.not_a_time, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
-- Check that the minutes are less than 60 if we have an hours field.
if hours and tonumber(minutes) >= 60 then
self:addWarning(
string.format(cfg.more_than_60_minutes, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
-- Check that the seconds are less than 60
if tonumber(seconds) >= 60 then
self:addWarning(
string.format(cfg.more_than_60_seconds, mw.text.nowiki(length)),
cfg.input_error_category
)
end
return nil
end
--------------------------------------------------------------------------------
-- Track class
--------------------------------------------------------------------------------
local Track = {}
Track.__index = Track
addMixin(Track, Validation)
Track.fields = cfg.track_field_names
Track.cellMethods = {
number = 'makeNumberCell',
title = 'makeTitleCell',
writer = 'makeWriterCell',
lyrics = 'makeLyricsCell',
music = 'makeMusicCell',
extra = 'makeExtraCell',
length = 'makeLengthCell',
}
function Track.new(data)
local self = setmetatable({}, Track)
Validation.init(self)
for field in pairs(Track.fields) do
self[field] = data[field]
end
self.number = assert(tonumber(self.number))
self:validateLength(self.length)
return self
end
function Track:getLyricsCredit()
return self.lyrics
end
function Track:getMusicCredit()
return self.music
end
function Track:getWriterCredit()
return self.writer
end
function Track:getExtraField()
return self.extra
end
-- Note: called with single dot syntax
function Track.makeSimpleCell(wikitext)
return mw.html.create('td')
:wikitext(wikitext or cfg.blank_cell)
end
function Track:makeNumberCell()
return mw.html.create('th')
:attr('id', string.format(cfg.track_id, self.number))
:attr('scope', 'row')
:wikitext(string.format(cfg.number_terminated, self.number))
end
function Track:makeTitleCell()
local titleCell = mw.html.create('td')
titleCell:wikitext(
self.title and string.format(cfg.track_title, self.title) or cfg.untitled
)
if self.note then
titleCell:wikitext(string.format(cfg.note, self.note))
end
return titleCell
end
function Track:makeWriterCell()
return Track.makeSimpleCell(self.writer)
end
function Track:makeLyricsCell()
return Track.makeSimpleCell(self.lyrics)
end
function Track:makeMusicCell()
return Track.makeSimpleCell(self.music)
end
function Track:makeExtraCell()
return Track.makeSimpleCell(self.extra)
end
function Track:makeLengthCell()
return mw.html.create('td')
:addClass('tracklist-length')
:wikitext(self.length or cfg.blank_cell)
end
function Track:exportRow(columns)
local columns = columns or {}
local row = mw.html.create('tr')
for i, column in ipairs(columns) do
local method = Track.cellMethods[column]
if method then
row:node(self[method](self))
end
end
return row
end
--------------------------------------------------------------------------------
-- TrackListing class
--------------------------------------------------------------------------------
local TrackListing = {}
TrackListing.__index = TrackListing
addMixin(TrackListing, Validation)
TrackListing.fields = cfg.track_listing_field_names
TrackListing.deprecatedFields = cfg.deprecated_track_listing_field_names
function TrackListing.new(data)
local self = setmetatable({}, TrackListing)
Validation.init(self)
-- Check for deprecated arguments
for deprecatedField in pairs(TrackListing.deprecatedFields) do
if data[deprecatedField] then
self:addCategory(cfg.deprecated_parameter_category)
break
end
end
-- Validate total length
if data.total_length then
self:validateLength(data.total_length)
end
-- Add properties
for field in pairs(TrackListing.fields) do
self[field] = data[field]
end
-- Evaluate boolean properties
self.showCategories = yesno(self.category) ~= false
self.category = nil
-- Make track objects
self.tracks = {}
for i, trackData in ipairs(data.tracks or {}) do
table.insert(self.tracks, Track.new(trackData))
end
-- Find which of the optional columns we have.
-- We could just check every column for every track object, but that would
-- be no fun^H^H^H^H^H^H inefficient, so we use four different strategies
-- to try and check only as many columns and track objects as necessary.
do
local optionalColumns = {}
local columnMethods = {
lyrics = 'getLyricsCredit',
music = 'getMusicCredit',
writer = 'getWriterCredit',
extra = 'getExtraField',
}
local doneWriterCheck = false
for i, trackObj in ipairs(self.tracks) do
for column, method in pairs(columnMethods) do
if trackObj[method](trackObj) then
optionalColumns[column] = true
columnMethods[column] = nil
end
end
if not doneWriterCheck and optionalColumns.writer then
doneWriterCheck = true
optionalColumns.lyrics = nil
optionalColumns.music = nil
columnMethods.lyrics = nil
columnMethods.music = nil
end
if not next(columnMethods) then
break
end
end
self.optionalColumns = optionalColumns
end
return self
end
--------------------------------------------------------------------------------
-- Function for automatic punctuation for parameters:
-- all_writing, all_lyrics, all_music
-- Punctuation defaults to '.' unless ':' or '.' already exist
-- Automatic punctuation limited to parameter values not containing parser tags
-- i.e. <ref>Text</ref>, <nowiki></nowiki>, etc.
--------------------------------------------------------------------------------
function fullstop(a)
if a ~= mw.text.killMarkers(mw.getCurrentFrame():preprocess(a)) or
a:sub(-1,-1) == ":" or
a:sub(-1,-1) == "." then
return a
else
return a .. '.'
end
end
function TrackListing:makeIntro()
if self.all_writing then
return string.format(cfg.tracks_written, fullstop(self.all_writing))
elseif self.all_lyrics and self.all_music then
return mw.message.newRawMessage(
cfg.lyrics_written_music_composed,
self.all_lyrics,
fullstop(self.all_music)
):plain()
elseif self.all_lyrics then
return string.format(cfg.lyrics_written, fullstop(self.all_lyrics))
elseif self.all_music then
return string.format(cfg.music_composed, fullstop(self.all_music))
else
return nil
end
end
function TrackListing:renderTrackingCategories()
if not self.showCategories or mw.title.getCurrentTitle().namespace ~= 0 then
return ''
end
local ret = ''
local function addCategory(cat)
ret = ret .. string.format('[[Category:%s]]', cat)
end
for i, category in ipairs(self:getCategories()) do
addCategory(category)
end
for i, track in ipairs(self.tracks) do
for j, category in ipairs(track:getCategories()) do
addCategory(category)
end
end
return ret
end
function TrackListing:renderWarnings()
if not cfg.show_warnings then
return ''
end
local ret = {}
local function addWarning(msg)
table.insert(ret, string.format(cfg.track_listing_error, msg))
end
for i, warning in ipairs(self:getWarnings()) do
addWarning(warning)
end
for i, track in ipairs(self.tracks) do
for j, warning in ipairs(track:getWarnings()) do
addWarning(warning)
end
end
return table.concat(ret, '<br>')
end
function TrackListing:__tostring()
-- Root of the output
local root = mw.html.create('div')
:addClass('track-listing')
local intro = self:makeIntro()
if intro then
root:tag('p')
:wikitext(intro)
:done()
end
-- Start of track listing table
local tableRoot = mw.html.create('table')
tableRoot
:addClass('tracklist')
-- Overall table width
if self.width then
tableRoot
:css('width', self.width)
end
-- Header row
if self.headline then
tableRoot:tag('caption')
:wikitext(self.headline or cfg.track_listing)
end
-- Headers
local headerRow = tableRoot:tag('tr')
---- Track number
headerRow
:tag('th')
:addClass('tracklist-number-header')
:attr('scope', 'col')
:tag('abbr')
:attr('title', cfg.number)
:wikitext(cfg.number_abbr)
-- Find columns to output
local columns = {'number', 'title'}
if self.optionalColumns.writer then
columns[#columns + 1] = 'writer'
else
if self.optionalColumns.lyrics then
columns[#columns + 1] = 'lyrics'
end
if self.optionalColumns.music then
columns[#columns + 1] = 'music'
end
end
if self.optionalColumns.extra then
columns[#columns + 1] = 'extra'
end
columns[#columns + 1] = 'length'
-- Find column width
local nColumns = #columns
local nOptionalColumns = nColumns - 3
local titleColumnWidth = 100
if nColumns >= 5 then
titleColumnWidth = 40
elseif nColumns >= 4 then
titleColumnWidth = 60
end
local optionalColumnWidth = ((100 - titleColumnWidth) / nOptionalColumns) .. '%'
titleColumnWidth = titleColumnWidth .. '%'
---- Title column
headerRow:tag('th')
:attr('scope', 'col')
:css('width', self.title_width or titleColumnWidth)
:wikitext(cfg.title)
---- Optional headers: writer, lyrics, music, and extra
local function addOptionalHeader(field, headerText, width)
if self.optionalColumns[field] then
headerRow:tag('th')
:attr('scope', 'col')
:css('width', width or optionalColumnWidth)
:wikitext(headerText)
end
end
addOptionalHeader('writer', cfg.writer, self.writing_width)
addOptionalHeader('lyrics', cfg.lyrics, self.lyrics_width)
addOptionalHeader('music', cfg.music, self.music_width)
addOptionalHeader(
'extra',
self.extra_column or cfg.extra,
self.extra_width
)
---- Track length
headerRow:tag('th')
:addClass('tracklist-length-header')
:attr('scope', 'col')
:wikitext(cfg.length)
-- Tracks
for i, track in ipairs(self.tracks) do
tableRoot:node(track:exportRow(columns))
end
-- Total length
if self.total_length then
tableRoot
:tag('tr')
:addClass('tracklist-total-length')
:tag('th')
:attr('colspan', nColumns - 1)
:attr('scope', 'row')
:tag('span')
:wikitext(cfg.total_length)
:done()
:done()
:tag('td')
:wikitext(self.total_length)
end
root:node(tableRoot)
-- Warnings and tracking categories
root:wikitext(self:renderWarnings())
root:wikitext(self:renderTrackingCategories())
return mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Module:Track listing/styles.css' }
} .. tostring(root)
end
--------------------------------------------------------------------------------
-- Exports
--------------------------------------------------------------------------------
local p = {}
function p._main(args)
-- Process numerical args so that we can iterate through them.
local data, tracks = {}, {}
for k, v in pairs(args) do
if type(k) == 'string' then
local prefix, num = k:match('^(%D.-)(%d+)$')
if prefix and Track.fields[prefix] and (num == '0' or num:sub(1, 1) ~= '0') then
-- Allow numbers like 0, 1, 2 ..., but not 00, 01, 02...,
-- 000, 001, 002... etc.
num = tonumber(num)
tracks[num] = tracks[num] or {}
tracks[num][prefix] = v
else
data[k] = v
end
end
end
data.tracks = (function (t)
-- Compress sparse array
local ret = {}
for num, trackData in pairs(t) do
trackData.number = num
table.insert(ret, trackData)
end
table.sort(ret, function (t1, t2)
return t1.number < t2.number
end)
return ret
end)(tracks)
return tostring(TrackListing.new(data))
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame, {
wrappers = 'Template:Track listing'
})
return p._main(args)
end
return p
ba53211a0ca356f872c9a88324fd2a6a9e8ff30a
Template:Track listing
10
407
574
2025-07-15T00:32:29Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
{{#invoke:Track listing|main}}<noinclude>
{{documentation}}
</noinclude>
bef48fe7b046d2e4f4a2ed058a47e1ec3b30ed00
Bleak Faith: Forsaken Original Soundtrack
0
413
586
2025-07-15T01:49:10Z
Sharparam
284703
Fix input error
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is a collection of songs that play throughout {{BFF}}. It is composed by [[Martel]] and [[Rade Vukčević]].
The soundtrack contains 44 tracks across all three discs with a combined total runtime of {{Duration|3:30:00|display=three and a half hours}}.
== Songs ==
<!--
// Generated using the following script on the Apple Music page:
(function() {
const discs = document.querySelectorAll('.section--disc');
console.debug(discs);
for (const disc of discs) {
const header = disc.querySelector('.disc-header h2.title').textContent;
const songs = disc.querySelectorAll('.songs-list .songs-list-row');
let total_length = 0;
const songData = Array.from(songs).map(s => {
const no = s.querySelector('.songs-list-row__song-index .songs-list-row__column-data').textContent;
const title = s.querySelector('.songs-list-row__song-name').textContent;
const length = s.querySelector('.songs-list-row__length').textContent;
const [mins, secs] = length.split(':').map(l => Number(l));
total_length += mins * 60 + secs;
return `| title${no} = ${title}\n| length${no} = ${length}`;
});
const tracks = songData.join("\n\n");
const tot_hors = Math.floor(total_length / 60 / 60);
const tot_mins = Math.floor((total_length - tot_hors * 60 * 60) / 60);
const tot_secs = total_length % 60;
const entry = `{{Track listing\n| headline = ${header}\n| total_length = ${tot_hors}:${tot_mins}:${tot_secs}\n\n${tracks}\n}}`;
console.info(entry);
}
})();
-->
{{Track listing
| headline = Disc 1
| total_length = 1:49:26
| title1 = Premonitions
| length1 = 3:19
| title2 = The Monastery
| length2 = 8:22
| title3 = Oathsworn
| length3 = 4:25
| title4 = The Imperial Siege
| length4 = 3:25
| title5 = Concrete Sea
| length5 = 4:32
| title6 = Sky Towers
| length6 = 9:23
| title7 = Downpour
| length7 = 9:12
| title8 = The Serdars
| length8 = 8:59
| title9 = The Inquisition
| length9 = 5:31
| title10 = The Valley
| length10 = 3:34
| title11 = The Trisagion
| length11 = 2:12
| title12 = Cloaca Maxima
| length12 = 3:15
| title13 = The Call of the Void
| length13 = 7:45
| title14 = The Machinarium
| length14 = 11:36
| title15 = A Bitter Evening
| length15 = 3:58
| title16 = Dreamlight
| length16 = 7:32
| title17 = The Instinct
| length17 = 2:27
| title18 = Recycled
| length18 = 3:00
| title19 = Domus Aurea
| length19 = 6:59
}}
{{Track listing
| headline = Disc 2
| total_length = 48:46
| title1 = Aurelian
| length1 = 5:31
| title2 = Vangelian
| length2 = 4:13
| title3 = Machinebirth
| length3 = 4:52
| title4 = Melanion
| length4 = 6:15
| title5 = Oberon
| length5 = 5:10
| title6 = Serapian
| length6 = 5:35
| title7 = Limitless
| length7 = 4:54
| title8 = The Fade
| length8 = 2:42
| title9 = Wandering
| length9 = 4:50
| title10 = Machinedream
| length10 = 4:44
}}
{{Track listing
| headline = Disc 3
| total_length = 52:11
| title1 = The Mountain Wreath
| length1 = 2:21
| title2 = Destiny
| length2 = 8:45
| title3 = Saberstorm
| length3 = 2:59
| title4 = Yaroslav's Rebellion
| length4 = 5:09
| title5 = The Nightmare (Menu Theme)
| length5 = 2:27
| title6 = Konrad the Traitor
| length6 = 2:49
| title7 = Yuliya
| length7 = 2:53
| title8 = Nemesis
| length8 = 3:04
| title9 = Belisarius
| length9 = 3:18
| title10 = Aberrant Knight
| length10 = 3:02
| title11 = Nurgei
| length11 = 3:15
| title12 = Wormlord
| length12 = 3:53
| title13 = Wyvern's Lament
| length13 = 3:52
| title14 = Doppelganger
| length14 = 2:22
| title15 = Baryak
| length15 = 2:02
}}
== External links ==
* [https://open.spotify.com/album/1cORrZ4GAVDbMvbEbvEL4q Spotify]
* [https://music.apple.com/ua/album/bleak-faith-original-soundtrack/1678680781 Apple Music]
* [https://martelvladimiroff.bandcamp.com/album/bleak-faith-forsaken Bandcamp]
d8060222851027ad9a4b2724ead306d2de16f292
Blade Dash
0
575
911
2025-07-15T20:18:43Z
Sharparam
284703
Fix image
wikitext
text/x-wiki
{{Infobox/Ability
| image = OrientalDash.png
| title = Blade Dash
| Cost = 45
| Cooldown = 15
| Description = Swing your weapon several times, dealing damage to all enemies in a frontal cone.
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
d8d63bcf9e2ab9e7610a637cbfae9e493d98a50d
Whirlwind Strike
0
576
913
2025-07-15T20:20:57Z
Sharparam
284703
Created page with "{{Infobox/Ability | image = OrientalSpin.png | title = Whirlwind Strike | Cost = 75 | Cooldown = 25 | Description = Swing your weapon several times, dealing damage to all enemies in a frontal cone. }} '''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}. {{Navbox/Abilities}}"
wikitext
text/x-wiki
{{Infobox/Ability
| image = OrientalSpin.png
| title = Whirlwind Strike
| Cost = 75
| Cooldown = 25
| Description = Swing your weapon several times, dealing damage to all enemies in a frontal cone.
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
e6c1e11c6f18f8785af475d924c7d62d672fe3b3
Dual Wields
0
474
712
2025-07-15T20:31:49Z
Sharparam
284703
Sharparam moved page [[Dual Wields]] to [[Dual Wield]]: Misspelled title: Called "Dual Wield" in-game
wikitext
text/x-wiki
#REDIRECT [[Dual Wield]]
f2856295451ab1cd2a686e19d6b0fbaa265f1d98
Template:Navbox/Equipment
10
437
634
2025-07-15T21:22:10Z
Sharparam
284703
Add more equipment
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Equipment
| title = [[Equipment]]
| group1 = [[Weapons]]
| list1 = {{Navbox/Weapons|child}}
| group2 = [[Armor]]
| list2 = {{Navbox/Armor|child}}
| group3 = [[Amulets]]
| list3 = {{Navbox/Amulets|child}}
| group4 = [[Rings]]
| list4 = {{Navbox/Rings|child}}
| group5 = [[Capes]]
| list5 = {{Navbox/Capes|child}}
}}
4e9b09f139c8eefe809a3e0918f7584ff16eb363
Template:Navbox/Items
10
285
312
311
2025-07-15T21:44:42Z
Sharparam
284703
Add some missing categories
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = Items
| group1 = [[Anomalous crystals]]
| list1 = {{Navbox/Anomalous crystals|child}}
| group2 = [[Consumables]]
| list2 = {{Navbox/Consumables|child}}
| group3 = [[Equipment]]
| list3 = {{Navbox/Equipment|child}}
}}
a411861b5bf4a6d8ba1b5a05f0287d3802aecd95
313
312
2025-07-15T22:49:03Z
Sharparam
284703
Add link to items page
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Anomalous crystals]]
| list1 = {{Navbox/Anomalous crystals|child}}
| group2 = [[Consumables]]
| list2 = {{Navbox/Consumables|child}}
| group3 = [[Equipment]]
| list3 = {{Navbox/Equipment|child}}
}}
ca3cdc023f216bb4caa76a9db8f95fb5602e929f
314
313
2025-07-16T02:49:01Z
Sharparam
284703
Add crafting items section
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Anomalous crystals]]
| list1 = {{Navbox/Anomalous crystals|child}}
| group2 = [[Consumables]]
| list2 = {{Navbox/Consumables|child}}
| group3 = [[Equipment]]
| list3 = {{Navbox/Equipment|child}}
| group4 = [[Crafting]]
| list4 = {{Navbox/Crafting items|child}}
}}
bf2478c6b03d574c41156fec247613edf994dde1
315
314
2025-07-16T02:56:59Z
Sharparam
284703
Fix materials group
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Anomalous crystals]]
| list1 = {{Navbox/Anomalous crystals|child}}
| group2 = [[Consumables]]
| list2 = {{Navbox/Consumables|child}}
| group3 = [[Equipment]]
| list3 = {{Navbox/Equipment|child}}
| group4 = [[Materials]]
| list4 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
57fc6de198843d9c4942092a4ee85caca6ff4037
316
315
2025-07-16T04:05:59Z
Sharparam
284703
Add some essential items
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = Essential
| list1 =
* [[Mobius Blade]]
* [[Old Key]]
* [[Scanner]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
3a6eb5fa278020754af0321a425464a6b8536c19
Equipment
0
467
698
2025-07-15T22:48:30Z
Sharparam
284703
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] that the player can wear.
{{Navbox/Equipment}}
c2de744eb63e9dbba3e8fff73404a00624386c66
Items
0
416
594
2025-07-15T22:49:50Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
'''{{PAGENAME}}''' come in various forms, from [[equipment]] that can be worn by the player, to [[consumables]] that can be used for various effects.
{{Navbox/Items}}
f9e1d38d5ce67ef854c74e6280c1d93d64ed929f
Citadel Warrior Chest
0
481
726
2025-07-15T23:06:59Z
Sharparam
284703
Add set name
wikitext
text/x-wiki
{{Infobox/Armor
| image = Citadel Warrior Chest.png
| title = {{PAGENAME}}
| Type = Chestguard
| Weight = Medium
| Set = Citadel Warrior
| Mk2_Sharp = 984
| Mk2_Blunt = 1296
| Mk2_Technomancy = 719
}}
{{Navbox/Armor}}
2d3a3133daf3387abf5d098ec92e1514330b81d4
Category:Chestguards
14
471
706
2025-07-15T23:12:42Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
[[Category:Armor]]
8dbf198b5dcaa87a18100850cc78880444b773ad
Template:Infobox/Armor set/doc
10
456
676
2025-07-15T23:32:11Z
Sharparam
284703
Fix wrong template used in example
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for an armor set",
"params": {
"image": {
"label": "Armor set image",
"description": "Name of the file used as the image for the armor set, should be at least 300 pixels wide.",
"required": true,
"example": "Cool armor set.png",
"type": "wiki-file-name"
},
"Weight": {
"label": "Armor set weight",
"description": "The weight class of the armor set.",
"required": true,
"example": "Light",
"type": "string"
},
"Helmet": {
"label": "Helmet piece",
"description": "The armor used for the helmet slot.",
"required": true,
"example": "Cool Helmet",
"type": "wiki-page-name"
},
"Pauldrons": {
"label": "Pauldrons piece",
"description": "The armor used for the pauldrons slot.",
"required": true,
"example": "Cool Pauldrons",
"type": "wiki-page-name"
},
"Chestguard": {
"label": "Chestguard piece",
"description": "The armor used for the chestguard slot.",
"required": true,
"example": "Cool Chestguard",
"type": "wiki-page-name"
},
"Legguard": {
"label": "Legguard piece",
"description": "The armor used for the legguard slot.",
"required": true,
"example": "Cool Legguard",
"type": "wiki-page-name"
},
"Gauntlets": {
"label": "Gauntlets piece",
"description": "The armor used for the gauntlets slot.",
"required": true,
"example": "Cool Gauntlets",
"type": "wiki-page-name"
},
"Mk1_Sharp": {
"label": "Mk 1 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Blunt": {
"label": "Mk 1 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Technomancy": {
"label": "Mk 1 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Sharp": {
"label": "Mk 2 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Blunt": {
"label": "Mk 2 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Technomancy": {
"label": "Mk 2 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Sharp": {
"label": "Mk 3 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Blunt": {
"label": "Mk 3 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Technomancy": {
"label": "Mk 3 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Sharp": {
"label": "Mk 4 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Blunt": {
"label": "Mk 4 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Technomancy": {
"label": "Mk 4 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Sharp": {
"label": "Mk 5 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Blunt": {
"label": "Mk 5 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Technomancy": {
"label": "Mk 5 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Armor set
| image = Awesome set.png
| title = Awesome set
| Weight = Heavy
| Helmet = Awesome Helmet
| Pauldrons = Awesome Pauldrons
| Chestguard = Awesome Chestguard
| Legguard = Awesome Legguard
| Gauntlets = Awesome Gauntlets
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Armor set
| image = Awesome set.png
| title = Awesome set
| Weight = Heavy
| Helmet = Awesome Helmet
| Pauldrons = Awesome Pauldrons
| Chestguard = Awesome Chestguard
| Legguard = Awesome Legguard
| Gauntlets = Awesome Gauntlets
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
</syntaxhighlight>
0b9b19ca76ed3cf82ad6c4644f7d39ea57f56907
Citadel Warrior
0
484
732
2025-07-15T23:34:49Z
Sharparam
284703
Remove redundant category entry
wikitext
text/x-wiki
{{Infobox/Armor set
| image = Citadel Warrior.png
| title = {{PAGENAME}}
| Weight = Medium
| Helmet = Citadel Warrior Helmet
| Pauldrons = Citadel Warrior Shoulders
| Chestguard = Citadel Warrior Chest
| Legguard = Citadel Warrior Legguards
| Gauntlets = Citadel Warrior Gauntlets
}}
'''{{PAGENAME}}''' is an [[armor set]] in {{BFF}}.
== Pieces ==
* [[Citadel Warrior Helmet]]
* [[Citadel Warrior Shoulders]]
* [[Citadel Warrior Chest]]
* [[Citadel Warrior Legguards]]
* [[Citadel Warrior Gauntlets]]
== See also ==
* [[Citadel Defender]] – Heavy variant with higher defense ratings.
{{Navbox/Armor}}
e1f48b76a2706b1879b8a99de8adffee44fc8785
Dual wield
0
473
710
2025-07-16T01:35:42Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
#REDIRECT [[Dual Wield]]
f2856295451ab1cd2a686e19d6b0fbaa265f1d98
Perk
0
746
1152
2025-07-16T01:36:24Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
#REDIRECT [[Perks]]
22eac196aff02ba31a4bced80e80fcfdc8051202
Perks
0
747
1154
2025-07-16T01:37:30Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful passive upgrades in {{BFF}}. The player can have up to four active perks at one time.
{{Navbox/Perks}}
26af41c73ec1c4e20599336d60d88a8378c8c6ab
Dual Wield Mastery
0
743
1146
2025-07-16T01:41:58Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
[[File:Dual_Wield_Mastery.png|thumb]]
'''{{PAGENAME}}''' is a [[perk]] in {{BFF}}. It improves proficiency with [[dual wield]] [[weapons]].
== Effect ==
Offhand weapons now deal 60% of their damage instead of 35%.
== Upgrades ==
* Critical Chance increases by 1% with each combo point while dual wielding.
* While dual wielding, you do not consume any stamina for melee attacks if at 15 or above combo points.
{{Navbox/Perks}}
[[Category:Perks]]
78e20c9ebd95bf46994bc694995631a11d79d8b6
Dual Wield
0
472
708
2025-07-16T02:01:29Z
Sharparam
284703
Add link to weapons page
wikitext
text/x-wiki
{{Stub}}
'''{{PAGENAME}}''' is a [[Weapons|weapon]] type in {{BFF}}.
== List of Dual Wields ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, speed=Speed, CONCAT('[[', damageType, ']]')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|where=type='Dual Wield'
|format=table
}}
[[Category:Dual Wields]]
6c2224d2e50f2da2b16a52ca04227ca57d27bbc8
Template:Navbox/Consumables
10
286
324
2025-07-16T02:08:19Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Greater Restorative Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Restorative Fluid]]
}}
068b364b9f72ace337b6eda9b1fad98cea7c7265
325
324
2025-07-16T02:10:01Z
Sharparam
284703
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Greater Restorative Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Restorative Fluid]]
}}
6b145de4128c95947cf01cfb2105da562d651fcc
326
325
2025-07-16T03:01:52Z
Sharparam
284703
Add missing consumables
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| group1 = Fluids
| list1 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Restorative Fluid]]
| group2 = Concoctions
| list2 =
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
}}
ce72b9ce75fe8de2da765ca2df5313636d5374d5
327
326
2025-07-16T03:03:30Z
Sharparam
284703
Add missing consumables
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Basilisk Hack]]
| group2 = Fluids
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Restorative Fluid]]
| group3 = Concoctions
| list3 =
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
* [[Experience Concoction]]
* [[Mystery Concoction]]
}}
f6d2786b1121af8c872d30d7b61e7d07d561e8cf
328
327
2025-07-16T03:03:55Z
Sharparam
284703
Add template category
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Basilisk Hack]]
| group2 = Fluids
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Restorative Fluid]]
| group3 = Concoctions
| list3 =
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
* [[Experience Concoction]]
* [[Mystery Concoction]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
29b982f060212718a4387efef495e9ad1b455ba9
329
328
2025-07-16T03:07:10Z
Sharparam
284703
Add more missing consumables
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
| group2 = Fluids
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
* [[Restorative Fluid]]
| group3 = Concoctions
| list3 =
* [[Diver's Lungs Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
* [[Concoction: Zealot's Tears]]
* [[Experience Concoction]]
* [[Mystery Concoction]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
e9736a1ea6833ecda5952ac6a85bce948c9cf19a
Consumables
0
428
618
2025-07-16T02:10:59Z
Sharparam
284703
Initial page
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[Items|item]] that the player can use to heal themselves, restore resources, or gain various buffs.
{{Navbox/Consumables}}
d9a89e867297dd4ee6e2667cdb541b327cdc74e4
NPC
0
367
496
2025-07-16T02:34:31Z
Sharparam
284703
Redirected page to [[NPCs]]
wikitext
text/x-wiki
#REDIRECT [[NPCs]]
0c78678b45694b9a9f67883eca2a30eaa6ea5607
Materials
0
431
624
2025-07-16T02:55:24Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' are [[items]] used to [[Crafting|craft]] or [[Manufacturing|manufacture]] other items. {{Navbox/Materials}}"
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] used to [[Crafting|craft]] or [[Manufacturing|manufacture]] other items.
{{Navbox/Materials}}
16c02de5636f61c53bd16cf7e1d04625cb9646e2
Template:Infobox/Cape/doc
10
463
690
2025-07-16T03:13:35Z
Sharparam
284703
Created page with "== Examples == {{Infobox/Cape | image = Cool cape.png | title = Cool cape | Effect1 = +50 coolness | Effect2 = -1s cooldowns }} <syntaxhighlight lang="wikitext"> {{Infobox/Cape | image = Cool cape.png | title = Cool cape | Effect1 = +50 coolness | Effect2 = -1s cooldowns }} </syntaxhighlight>"
wikitext
text/x-wiki
== Examples ==
{{Infobox/Cape
| image = Cool cape.png
| title = Cool cape
| Effect1 = +50 coolness
| Effect2 = -1s cooldowns
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Cape
| image = Cool cape.png
| title = Cool cape
| Effect1 = +50 coolness
| Effect2 = -1s cooldowns
}}
</syntaxhighlight>
90d89e60cc634d47fd7681de76278937e16255fc
Template:Navbox/Capes
10
287
331
2025-07-16T03:15:32Z
Sharparam
284703
Created page with "{{Navbox | template = Navbox/Capes | title = [[Capes]] | list1 = * [[Agile Cape]] * [[Fur Cape]] * [[Ronin Scarf]] * [[Sentinel Overcoat]] * [[Spectre Scarf]] * [[Tattered Cape]] * [[Traveler Cape]] * [[Wanderer Cape]] }}<noinclude>[[Category:Navigation templates]]</noinclude>"
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Capes
| title = [[Capes]]
| list1 =
* [[Agile Cape]]
* [[Fur Cape]]
* [[Ronin Scarf]]
* [[Sentinel Overcoat]]
* [[Spectre Scarf]]
* [[Tattered Cape]]
* [[Traveler Cape]]
* [[Wanderer Cape]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
0d84fc50e23693f75a69a43dd191d9913b09c6bd
332
331
2025-07-16T03:15:49Z
Sharparam
284703
Add missing param passthrough
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Capes
| title = [[Capes]]
| list1 =
* [[Agile Cape]]
* [[Fur Cape]]
* [[Ronin Scarf]]
* [[Sentinel Overcoat]]
* [[Spectre Scarf]]
* [[Tattered Cape]]
* [[Traveler Cape]]
* [[Wanderer Cape]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
b29e7b93ce7ebeee0420b0126beba25917db3c9f
Wanderer Cape
0
512
787
2025-07-16T03:18:07Z
Sharparam
284703
Created page with "{{Infobox/Cape | title = {{PAGENAME}} | image = Wanderer Cape.png | Effect1 = -0.5 second delay before stamina starts to regenerate. }} '''{{PAGENAME}}''' is a [[Capes|cape]] that can be worn in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Infobox/Cape
| title = {{PAGENAME}}
| image = Wanderer Cape.png
| Effect1 = -0.5 second delay before stamina starts to regenerate.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] that can be worn in {{BFF}}.
{{Navbox/Capes}}
1f5137f1dafe59cd4ffe5c3b254751901918d15e
Capes
0
443
651
2025-07-16T03:19:24Z
Sharparam
284703
Fix grammar
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] the player can wear to gain various bonus stats or effects.
{{Navbox/Capes}}
e68b383acdf3f302a6ce54944a3b34f545506c55
Template:Infobox/Ability
10
459
682
2025-07-16T03:20:32Z
Sharparam
284703
Add template category
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=ability
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info,Description
|Basic Info=Cost,Cooldown
|Cost_label=Flux cost
|Cooldown={{#if:{{{Cooldown|}}}|{{{Cooldown}}} seconds}}
|Description_nolabel=yes
|Description_isdata=yes
}}{{#if:{{NAMESPACE}}||[[Category:Abilities]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
c1ad1894018a724cf6235cea17b860aa85344fed
Template:Infobox/Armor set
10
455
674
2025-07-16T03:21:07Z
Sharparam
284703
Add template category
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor-set
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Pieces, Stats
|Basic Info=Weight
|Pieces=Helmet,Pauldrons,Chestguard,Legguard,Gauntlets
|Helmet={{#if:{{{Helmet|}}}|[[{{{Helmet}}}]]}}
|Pauldrons={{#if:{{{Pauldrons|}}}|[[{{{Pauldrons}}}]]}}
|Chestguard={{#if:{{{Chestguard|}}}|[[{{{Chestguard}}}]]}}
|Legguard={{#if:{{{Legguard|}}}|[[{{{Legguard}}}]]}}
|Gauntlets={{#if:{{{Gauntlets|}}}|[[{{{Gauntlets}}}]]}}
|tabs=
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||[[Category:Armor sets]]}}</includeonly><noinclude>
{{Documentation}}[[Category:Infobox templates]]</noinclude>
d0b44e9f72dec247f40dfa79c3541b37ed9c3937
Template:Infobox/Cape
10
462
688
2025-07-16T03:21:20Z
Sharparam
284703
Add template category
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=cape
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Effects
|Effects=Effect1,Effect2,Effect3
|Effect1_nolabel=yes
|Effect2_nolabel=yes
|Effect3_nolabel=yes
}}{{#if:{{NAMESPACE}}||[[Category:Capes]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
1957e3d416bf10a10bad93e51f649ad4f1768848
Template:Navbox/Anomalous crystals
10
288
337
2025-07-16T03:24:08Z
Sharparam
284703
Created page with "{{Navbox | template = Navbox/Anomalous crystals | title = [[Anomalous crystals]] | list1= * [[Lesser Anomalous Crystal]] * [[Anomalous Crystal]] * [[Greater Anomalous Crystal]] }}<noinclude>[[Category:Navigation templates]]</noinclude>"
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Anomalous crystals
| title = [[Anomalous crystals]]
| list1=
* [[Lesser Anomalous Crystal]]
* [[Anomalous Crystal]]
* [[Greater Anomalous Crystal]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
6702c38b572ae6caefc04acd4b08e219bf9a5d68
338
337
2025-07-16T03:24:22Z
Sharparam
284703
Add missing param passthrough
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Anomalous crystals
| title = [[Anomalous crystals]]
| list1=
* [[Lesser Anomalous Crystal]]
* [[Anomalous Crystal]]
* [[Greater Anomalous Crystal]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ebedb2789af69363588ddf5553b8868dcbf7005d
Lore
0
371
504
2025-07-16T03:47:22Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' can be found as text on [[items]], various [[data logs]] and [[documents]], and [[NPC]] dialogue in {{BFF}}. == Data logs == {{Main|Data logs}} == Documents == {{Main|Documents}} {{Navbox/Lore}} [[Category:Lore]]"
wikitext
text/x-wiki
'''{{PAGENAME}}''' can be found as text on [[items]], various [[data logs]] and [[documents]], and [[NPC]] dialogue in {{BFF}}.
== Data logs ==
{{Main|Data logs}}
== Documents ==
{{Main|Documents}}
{{Navbox/Lore}}
[[Category:Lore]]
3efab73936854b174032435bb0c6f8b77736139d
Template:Navbox/Lore
10
289
340
2025-07-16T03:50:26Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Lore | title = [[Lore]] | group1 = [[Data logs]] | list1 = * [[Monastery Impression]] * [[Monastery Observation]] * [[Dreadguard]] * [[Inquisitors]] * [[Eternal Rain]] * [[Habitation]] * [[Industrial Silence]] * [[Encrypted Radiation]] * [[The Deep Monastery]] * [[Monolith]] * [[Desert Whispers]] * [[Asylum (data log)|Asylum]] * [[Terror]] * [[The Deep]] * [[A Vision]] * [[The Drone]] * [[Calcified Lives]] * [[Manta Rays]] * The..."
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Lore
| title = [[Lore]]
| group1 = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
| group2 = [[Documents]]
| list2 =
}}<noinclude>[[Category:Navigation templates]]</noinclude>
1db288cb2f5c6f51241b5be78a1ec242687b398b
341
340
2025-07-16T03:51:13Z
Sharparam
284703
Add documents
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Lore
| title = [[Lore]]
| group1 = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
| group2 = [[Documents]]
| list2 =
* [[Konrad's War Log]]
* [[Helena's Diary Fragment]]
* [[Hellicar's Maxims]]
* [[Guiscard's Manifest]]
* [[Untitled Log]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
753896515d0e262801ebc6f6c76b02000f959d56
342
341
2025-07-16T03:51:45Z
Sharparam
284703
Move data logs to own navbox
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Lore
| title = [[Lore]]
| group1 = [[Data logs]]
| list1 = {{Navbox/Data logs|child}}
| group2 = [[Documents]]
| list2 =
* [[Konrad's War Log]]
* [[Helena's Diary Fragment]]
* [[Hellicar's Maxims]]
* [[Guiscard's Manifest]]
* [[Untitled Log]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
35a5da538ee72dc5a83dbbb27fd8f38e54f93c7c
343
342
2025-07-16T03:53:21Z
Sharparam
284703
Move documents to own navbox
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Lore
| title = [[Lore]]
| group1 = [[Data logs]]
| list1 = {{Navbox/Data logs|child}}
| group2 = [[Documents]]
| list2 = {{Navbox/Documents|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
cc386cacfb50aa464ec9e6065463991e75c6ef65
Template:Navbox/Data logs
10
290
345
2025-07-16T03:52:43Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Data logs | title = [[Data logs]] | list1 = * [[Monastery Impression]] * [[Monastery Observation]] * [[Dreadguard]] * [[Inquisitors]] * [[Eternal Rain]] * [[Habitation]] * [[Industrial Silence]] * [[Encrypted Radiation]] * [[The Deep Monastery]] * [[Monolith]] * [[Desert Whispers]] * [[Asylum (data log)|Asylum]] * [[Terror]] * [[The Deep]] * [[A Vision]] * [[The Drone]] * [[Calcified Lives]] * [[Manta Rays]] * [[The Structure]] }}<..."
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
a835cd772b8a5f1437f310d8490931607791fc25
Template:Navbox/Documents
10
291
368
2025-07-16T03:53:56Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Documents | title = [[Documents]] | list1 = * [[Konrad's War Log]] * [[Helena's Diary Fragment]] * [[Hellicar's Maxims]] * [[Guiscard's Manifest]] * [[Untitled Log]] }}<noinclude>[[Category:Navigation templates]]</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Documents
| title = [[Documents]]
| list1 =
* [[Konrad's War Log]]
* [[Helena's Diary Fragment]]
* [[Hellicar's Maxims]]
* [[Guiscard's Manifest]]
* [[Untitled Log]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
4859742a1634980b598ee96ab98cf1b44828e159
Monastery Impression
0
370
502
2025-07-16T03:56:10Z
Sharparam
284703
Fix casing
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] that can be found at [[Monastery|the Monastery]] in {{BFF}}.
== Overview ==
{{Quote
| Venturing into the anomalous zone at the edge of this crumbling colony, I was enveloped by a world devoid of sense, dominated by the cold, relentless sprawl of concrete and rebar. Rusted metal carcasses of buildings stood as grim monuments to a forgotten era, their skeletal frames interwoven with the vestiges of ancient technology and tangled cables that snaked across the ground like decaying veins. The omnipresent drone of [[Omnistructure|the structure]] reverberated through the air, a constant reminder of its oppressive presence – here, louder than anywhere before. As I picked my way through the debris, I could sense the weight of the past pressing in, the technological remnants whispering secrets of a world that once thrived but now lay silent and corroded.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
5d6199c92d0ebf1baedb5890d3776274eadefaef
Documents
0
373
508
2025-07-16T03:58:18Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' are [[lore]] [[items]] that can be found in the world of {{BFF}}. == Overview == Documents are typically found as drops from [[enemies]]. {{Navbox/Documents}} [[Category:Lore]] [[Category:Documents]]"
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[items]] that can be found in the world of {{BFF}}.
== Overview ==
Documents are typically found as drops from [[enemies]].
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
3305c6ccf580021e8513f612ab7919e6863f1f47
Data logs
0
372
506
2025-07-16T03:59:46Z
Sharparam
284703
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[items]] that can be found in the world of {{BFF}}.
== Overview ==
Data logs are uncovered by interacting at certain specific points in the game world. To locate these points, use of the [[Scanner]] is recommended.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
0b268f9f4958f98eba1f00ec6c06edbba3c10826
Template:Infobox/Item/doc
10
464
692
2025-07-16T04:02:44Z
Sharparam
284703
Created page with "== Examples == {{Infobox/Item | image = Fancy item.png | title = Fancy item | Description = This item will do something fancy when you use it! }} <syntaxhighlight lang="wikitext"> {{Infobox/Item | image = Fancy item.png | title = Fancy item | Description = This item will do something fancy when you use it! }} </syntaxhighlight>"
wikitext
text/x-wiki
== Examples ==
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| Description = This item will do something fancy when you use it!
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| Description = This item will do something fancy when you use it!
}}
</syntaxhighlight>
9a956a5275f4ed54d4ffea9d646a5229cadc93a6
Template:Reflist/styles.css
10
616
969
2025-07-16T05:41:40Z
Sharparam
284703
Copied from [[mediawiki:Template:Reflist/styles.css]]
sanitized-css
text/css
.reflist {
list-style-type: decimal;
margin-bottom: 0.5em;
}
@media screen {
.reflist {
font-size: 0.9em; /* Make default font smaller only on screens. */
}
}
.reflist .references {
font-size: 1em; /* Reset font size when nested in reflist. */
list-style-type: inherit; /* Enable custom list-style types. */
margin-bottom: 0; /* Avoid double margin when nested in reflist. */
}
.reflist-columns {
margin-top: 0.3em; /* Reset top margin for column-embedded lists. */
}
.reflist-columns ol {
margin-top: 0;
}
.reflist-columns li {
break-inside: avoid-column; /* Avoid elements breaking between columns. */
}
.reflist-upper-alpha {
list-style-type: upper-alpha;
}
.reflist-upper-roman {
list-style-type: upper-roman;
}
.reflist-lower-alpha {
list-style-type: lower-alpha;
}
.reflist-lower-greek {
list-style-type: lower-greek;
}
.reflist-lower-roman {
list-style-type: lower-roman;
}
e2f766e5d4d3ee66aca32f6714fef1bc97648e0a
Template:Notelist
10
612
961
2025-07-16T05:42:49Z
Sharparam
284703
Copied from [[mediawiki:Template:Notelist]]
wikitext
text/x-wiki
{{safesubst<noinclude />:Reflist|{{{1|{{{colwidth|}}}}}}|refs={{{refs|{{{notes|}}}}}}|group={{safesubst<noinclude />:#switch:{{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}}}{{safesubst<noinclude />:#invoke:Check for unknown parameters|check|unknown={{Main other|[[Category:Pages using notelist with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Notelist]] with unknown parameter "_VALUE_"|ignoreblank=y| 1 | colwidth | group | notes | refs }}<noinclude>
{{Documentation}}</noinclude>
94f17b894235ff18c73072096f5940cdbcc5b719
Template:Note
10
615
967
2025-07-16T05:49:15Z
Sharparam
284703
Copied from [[mediawiki:Template:Efn]]
wikitext
text/x-wiki
<includeonly>{{#if:{{{name|}}}
|{{#tag:ref|{{{1|{{{reference|{{{content|{{{text|}}}}}}}}}}}}|name={{{name|}}}|group={{#switch: {{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}
}}
|{{#tag:ref|{{{1|{{{reference|{{{content|{{{text|}}}}}}}}}}}}|group={{#switch: {{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}
}}
}}</includeonly><noinclude>
{{documentation}}
</noinclude>
6ed4e5c148014b92a23bd51d16f3180881bb876c
Template:Ref
10
617
971
2025-07-16T05:52:58Z
Sharparam
284703
Copied from [[wikipedia:Template:Refn]]
wikitext
text/x-wiki
<includeonly>{{#if:{{{follow|}}}|{{#tag:ref|{{{1|{{{refn|}}}}}}|group={{{group|}}}|follow={{{follow|}}}}}|{{#if:{{{name|}}}|{{#tag:ref|{{{1|{{{refn|}}}}}}|name={{{name|}}}|group={{{group|}}}}}|{{#tag:ref|{{{1|{{{refn|}}}}}}|group={{{group|}}}}}}}}}</includeonly><noinclude>{{documentation}}</noinclude>
9fd4ba12eab57eadfed1197d60df81947547d276
MediaWiki:Cite link label group-lower-alpha
8
618
973
2025-07-16T05:56:10Z
Sharparam
284703
Copied from [[wikipedia:MediaWiki:Cite link label group-lower-alpha]]
wikitext
text/x-wiki
a b c d e f g h i j k l m n o p q r s t u v w x y z aa ab ac ad ae af ag ah ai aj ak al am an ao ap aq ar as at au av aw ax ay az ba bb bc bd be bf bg bh bi bj bk bl bm bn bo bp bq br bs bt bu bv bw bx by bz ca cb cc cd ce cf cg ch ci cj ck cl cm cn co cp cq cr cs ct cu cv cw cx cy cz da db dc dd de df dg dh di dj dk dl dm dn do dp dq dr ds dt du dv dw dx dy dz ea eb ec ed ee ef eg eh ei ej ek el em en eo ep eq er es et eu ev ew ex ey ez fa fb fc fd fe ff fg fh fi fj fk fl fm fn fo fp fq fr fs ft fu fv fw fx fy fz ga gb gc gd ge gf gg gh gi gj gk gl gm gn go gp gq gr gs gt gu gv gw gx gy gz ha hb hc hd he hf hg hh hi hj hk hl hm hn ho hp hq hr hs ht hu hv hw hx hy hz ia ib ic id ie if ig ih ii ij ik il im in io ip iq ir is it iu iv iw ix iy iz ja jb jc jd je jf jg jh ji jj jk jl jm jn jo jp jq jr js jt ju jv jw jx jy jz ka kb kc kd ke kf kg kh ki kj kk kl km kn ko kp kq kr ks kt ku kv kw kx ky kz la lb lc ld le lf lg lh li lj lk ll lm ln lo lp lq lr ls lt lu lv lw lx ly lz ma mb mc md me mf mg mh mi mj mk ml mm mn mo mp mq mr ms mt mu mv mw mx my mz na nb nc nd ne nf ng nh ni nj nk nl nm nn no np nq nr ns nt nu nv nw nx ny nz oa ob oc od oe of og oh oi oj ok ol om on oo op oq or os ot ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj pk pl pm pn po pp pq pr ps pt pu pv pw px py pz qa qb qc qd qe qf qg qh qi qj qk ql qm qn qo qp qq qr qs qt qu qv qw qx qy qz ra rb rc rd re rf rg rh ri rj rk rl rm rn ro rp rq rr rs rt ru rv rw rx ry rz sa sb sc sd se sf sg sh si sj sk sl sm sn so sp sq sr ss st su sv sw sx sy sz ta tb tc td te tf tg th ti tj tk tl tm tn to tp tq tr ts tt tu tv tw tx ty tz ua ub uc ud ue uf ug uh ui uj uk ul um un uo up uq ur us ut uu uv uw ux uy uz va vb vc vd ve vf vg vh vi vj vk vl vm vn vo vp vq vr vs vt vu vv vw vx vy vz wa wb wc wd we wf wg wh wi wj wk wl wm wn wo wp wq wr ws wt wu wv ww wx wy wz xa xb xc xd xe xf xg xh xi xj xk xl xm xn xo xp xq xr xs xt xu xv xw xx xy xz ya yb yc yd ye yf yg yh yi yj yk yl ym yn yo yp yq yr ys yt yu yv yw yx yy yz za zb zc zd ze zf zg zh zi zj zk zl zm zn zo zp zq zr zs zt zu zv zw zx zy zz aaa aab aac aad aae aaf aag aah aai aaj aak aal aam aan aao aap aaq aar aas aat aau aav aaw aax aay aaz aba abb abc abd abe abf abg abh abi abj abk abl abm abn abo abp abq abr abs abt abu abv abw abx aby abz aca acb acc acd ace acf acg ach aci acj ack acl acm acn aco acp acq acr acs act acu acv acw acx acy acz ada adb adc add ade adf adg adh adi adj adk adl adm adn ado adp adq adr ads adt adu adv adw adx ady adz aea aeb aec aed aee aef aeg aeh aei aej aek ael aem aen aeo aep aeq aer aes aet aeu aev aew aex aey aez afa afb afc afd afe aff afg afh afi afj afk afl afm afn afo afp afq afr afs aft afu afv afw afx afy afz aga agb agc agd age agf agg agh agi agj agk agl agm agn ago agp agq agr ags agt agu agv agw agx agy agz aha ahb ahc ahd ahe ahf ahg ahh ahi ahj ahk ahl ahm ahn aho ahp ahq ahr ahs aht ahu ahv ahw ahx ahy ahz aia aib aic aid aie aif aig aih aii aij aik ail aim ain aio aip aiq air ais ait aiu aiv aiw aix aiy aiz aja ajb ajc ajd aje ajf ajg ajh aji ajj ajk ajl ajm ajn ajo ajp ajq ajr ajs ajt aju ajv ajw ajx ajy ajz aka akb akc akd ake akf akg akh aki akj akk akl akm akn ako akp akq akr aks akt aku akv akw akx aky akz ala alb alc ald ale alf alg alh ali alj alk all alm aln alo alp alq alr als alt alu alv alw alx aly alz ama amb amc amd ame amf amg amh ami amj amk aml amm amn amo amp amq amr ams amt amu amv amw amx amy amz ana anb anc and ane anf ang anh ani anj ank anl anm ann ano anp anq anr ans ant anu anv anw anx any anz aoa aob aoc aod aoe aof aog aoh aoi aoj aok aol aom aon aoo aop aoq aor aos aot aou aov aow aox aoy aoz apa apb apc apd ape apf apg aph api apj apk apl apm apn apo app apq apr aps apt apu apv apw apx apy apz aqa aqb aqc aqd aqe aqf aqg aqh aqi aqj aqk aql aqm aqn aqo aqp aqq aqr aqs aqt aqu aqv aqw aqx aqy aqz ara arb arc ard are arf arg arh ari arj ark arl arm arn aro arp arq arr ars art aru arv arw arx ary arz asa asb asc asd ase asf asg ash asi asj ask asl asm asn aso asp asq asr ass ast asu asv asw asx asy asz ata atb atc atd ate atf atg ath ati atj atk atl atm atn ato atp atq atr ats att atu atv atw atx aty atz aua aub auc aud aue auf aug auh aui auj auk aul aum aun auo aup auq aur aus aut auu auv auw aux auy auz ava avb avc avd ave avf avg avh avi avj avk avl avm avn avo avp avq avr avs avt avu avv avw avx avy avz awa awb awc awd awe awf awg awh awi awj awk awl awm awn awo awp awq awr aws awt awu awv aww awx awy awz axa axb axc axd axe axf axg axh axi axj axk axl axm axn axo axp axq axr axs axt axu axv axw axx axy axz aya ayb ayc ayd aye ayf ayg ayh ayi ayj ayk ayl aym ayn ayo ayp ayq ayr ays ayt ayu ayv ayw ayx ayy ayz aza azb azc azd aze azf azg azh azi azj azk azl azm azn azo azp azq azr azs azt azu azv azw azx azy azz
b49c822b47338613f0c10a02bd4f6a2a6735e324
Untitled Log
0
369
500
2025-07-16T05:56:29Z
Sharparam
284703
Use note templates
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[lore]] [[Documents|document]] that can be found in {{BFF}}.
== Overview ==
There are multiple untitled logs in the game, each with their own text.
{{Quote
|I remember waking in a pile of lifeless bodies. Not only lifeless though. Expressionless. Frozen visages.
}}
{{Quote
| Like waking from a dream about dreaming, everything is a haze. A dark ominous haze. I've seen death, pain, and torture. I hear a voice. Once in a while I see the voice beckon, like a ripple in water – before I can make form of the image. I am gone too.
}}
{{Quote
| I have no mouth, and I know nobody would hear me scream.{{note|Likely a reference to [[wikipedia:I Have No Mouth, and I Must Scream|I Have No Mouth, and I Must Scream]].}}
}}
{{Quote
| No matter where my mind wanders, there is an oppressive red mist crushing the reaches of my imagination. Try as I might, there seems to be no escape. No escape. Only a journey deeper. Farther.. but what awaits at the innermost depths. I suppose the [[Omnistructure]] makes room beyond sense.. beyond time.
}}
== Notes ==
{{notelist}}
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
472bf3de6dbca52f57c3f288b12ad3650a51f3b6
Template:Reflist
10
613
963
2025-07-16T08:32:37Z
Sharparam
284703
Protected "[[Template:Reflist]]": Stable template ([Edit=Allow only administrators] (indefinite) [Move=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<templatestyles src="Reflist/styles.css" /><div class="reflist<!--
-->{{#if:{{{1|}}}{{{colwidth|}}}| reflist-columns references-column-width}} {{#switch:{{{liststyle|{{{group|}}}}}}
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = reflist-{{{liststyle|{{{group}}}}}}
}}" <!-- End class, start style -->{{#if:{{{1|}}}
| {{#iferror:{{#ifexpr: {{{1|1}}} > 1 }} |style="column-width: {{{1}}};"}}
| {{#if: {{{colwidth|}}}|style="column-width: {{{colwidth}}};"}}
}}>
{{#tag:references|{{{refs|}}}|group={{{group|}}}|responsive={{#if:{{{1|}}}{{{colwidth|}}}|0|1}}}}</div>{{#invoke:Check for unknown parameters|check|unknown={{main other|[[Category:Pages using reflist with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Reflist]] with unknown parameter "_VALUE_"|ignoreblank=y| 1 | colwidth | group | liststyle | refs }}<noinclude>
{{Documentation}}</noinclude>
5865246773ff390ed5700866ea2396d78a81b01f
Template:Navbox/Capes
10
287
333
332
2025-07-16T18:35:43Z
Sharparam
284703
Add [[Folk Cape]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Capes
| title = [[Capes]]
| list1 =
* [[Agile Cape]]
* [[Folk Cape]]
* [[Fur Cape]]
* [[Ronin Scarf]]
* [[Sentinel Overcoat]]
* [[Spectre Scarf]]
* [[Tattered Cape]]
* [[Traveler Cape]]
* [[Wanderer Cape]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
d08fd75315ebac94e72678f90276c13a3506783a
334
333
2025-07-21T02:15:24Z
Sharparam
284703
Add [[Corrupted Cape]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Capes
| title = [[Capes]]
| list1 =
* [[Agile Cape]]
* [[Corrupted Cape]]
* [[Folk Cape]]
* [[Fur Cape]]
* [[Ronin Scarf]]
* [[Sentinel Overcoat]]
* [[Spectre Scarf]]
* [[Tattered Cape]]
* [[Traveler Cape]]
* [[Wanderer Cape]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
9f0729072622507472ffd1be806417db23ffe410
335
334
2025-07-21T04:04:55Z
Sharparam
284703
Add [[Techpriest Cape]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Capes
| title = [[Capes]]
| list1 =
* [[Agile Cape]]
* [[Corrupted Cape]]
* [[Folk Cape]]
* [[Fur Cape]]
* [[Ronin Scarf]]
* [[Sentinel Overcoat]]
* [[Spectre Scarf]]
* [[Tattered Cape]]
* [[Techpriest Cape]]
* [[Traveler Cape]]
* [[Wanderer Cape]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
25d3fe6cdc6b4cce6fe483d3b4b7218599b53b34
Dust Sea
0
375
512
2025-07-16T18:55:34Z
Sharparam
284703
Created page with "The '''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote | At the base of the sprawling mining facility, a deep mist blankets the ground, leading out to a vast, desolate desert. This desert's sand is a choking mix of dust and residue from the countless constructions and creations towering above. The air is perilous to breathe, laden with fine particles that can invade the lungs. Scattered across this wasteland are th..."
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
| At the base of the sprawling mining facility, a deep mist blankets the ground, leading out to a vast, desolate desert. This desert's sand is a choking mix of dust and residue from the countless constructions and creations towering above. The air is perilous to breathe, laden with fine particles that can invade the lungs. Scattered across this wasteland are the carcasses of long-forgotten machinery and the ruins of old structures. The architecture of these relics hints at a bygone era, a dark age marked by more primitive technology. This eerie landscape tells a silent tale of a past civilization, now buried beneath the relentless sands of time.
}}
== Location ==
{{coords|-4062|-2272|5797}}
Can be found at the top of a broken down tower in [[Deluge|the Deluge]] area, just past the [[Folk Cape]]. After reaching the first [[homunculus]] of the area, walk up the stairs (past [[The Handler]]) and head left. Continue forward until reaching the big tower, climb it to the top and you will find the data log at the edge of the tower (use [[Scanner|the Scanner]] to see it more easily).
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
90fdcaf4874fbb945c79bf4bf3df130f8ba25db5
Template:Navbox/Data logs
10
290
346
345
2025-07-16T18:55:55Z
Sharparam
284703
Add [[Dust Sea]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
214a4da82294ef39e752b290dbf6e8bbe5cab06f
347
346
2025-07-16T20:02:58Z
Sharparam
284703
Add [[Psychosis]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
2365608ea721de33b646b2deff88698eeb4f9b89
348
347
2025-07-21T04:12:14Z
Sharparam
284703
Add [[Night Horror]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ab06e89cfbb84fd1c6a88bd34ce62082702c1f11
349
348
2025-07-21T05:37:47Z
Sharparam
284703
Add [[The Banshee]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
8d4aa14493f7ae826b561ab952726806ac2be395
Folk Cape
0
513
789
2025-07-16T18:58:28Z
Sharparam
284703
Improve location description
wikitext
text/x-wiki
{{Infobox/Cape
| image = Folk Cape.png
| title = {{PAGENAME}}
| Effect1 = -20% Technocasting speed
| Effect2 = +10% [[Technomancy]] penetration
| Effect3 = +50 Max [[flux]] points
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] that can be worn by the player to gain certain effects.
== Location ==
{{coords|-3979|-2143|5796}}
At the top of a broken down tower in [[Deluge|the Deluge]] area, in front of [[Dust Sea|the Dust Sea]] [[Data logs|data log]]. After reaching the first [[homunculus]] of the area, walk up the stairs (past [[The Handler]]) and head left, then continue until you enter the big tower. Climb the tower to the top and you'll find the item on the ground at the top of the last set of stairs.
{{Navbox/Capes}}
ced1f8221d9ad9bf30775a81e257aa3efb4d12dd
Crude Helmet
0
489
742
2025-07-16T19:06:23Z
Sharparam
284703
Created page with "{{Infobox/Armor | image = Crude Helmet.png | title = {{PAGENAME}} | Type = Helmet | Weight = Medium | Mk2_Sharp = 516 | Mk2_Blunt = 600 | Mk2_Technomancy = 336 }} '''{{PAGENAME}}''' is a [[Helmets|helmet]] type of [[armor]] that can be found in {{BFF}}. == Location == {{coords|-3538|-6027|5477}} Found in [[Deluge|the Deluge]] area. After reaching the bottom of the big broken tower (where [[Folk Cape]] and [[Dust Sea|the Dust Sea]] can be found), continue right and fo..."
wikitext
text/x-wiki
{{Infobox/Armor
| image = Crude Helmet.png
| title = {{PAGENAME}}
| Type = Helmet
| Weight = Medium
| Mk2_Sharp = 516
| Mk2_Blunt = 600
| Mk2_Technomancy = 336
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] type of [[armor]] that can be found in {{BFF}}.
== Location ==
{{coords|-3538|-6027|5477}}
Found in [[Deluge|the Deluge]] area. After reaching the bottom of the big broken tower (where [[Folk Cape]] and [[Dust Sea|the Dust Sea]] can be found), continue right and follow the wall until you see a a corpse on a ledge holding the item.
{{Navbox/Armor}}
4327414a895ebc5fd2ac98909457618e6423b0f3
Template:Navbox/Rings
10
292
370
2025-07-16T19:11:48Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Rings | title = [[Rings]] | list1= * [[Ring of Burning Desire]] }}<noinclude>[[Category:Navigation templates]]</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
7e4970f06f67401009bd01cbb3fb3b4f7a0a3720
Rings
0
442
649
2025-07-16T19:12:25Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' are a type of [[equipment]] that can be worn by the player to gain certain effects. {{Navbox/Rings}} [[Category:Rings]]"
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] that can be worn by the player to gain certain effects.
{{Navbox/Rings}}
[[Category:Rings]]
7adf2438732889de3ab3158748516564e3c337cb
Ring of Burning Desire
0
519
801
2025-07-16T19:13:11Z
Sharparam
284703
remove "the" from "the Diver"
wikitext
text/x-wiki
{{Infobox/Ring
| image = Ring of Burning Desire.png
| title = {{PAGENAME}}
| Effect1 = +20% chance to inflict [[heat]] [[status effect]].
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] that can be found in {{BFF}}.
== Acquisition ==
Drops from [[Diver]] [[enemies]] in [[Deluge|the Deluge]] area.
{{Navbox/Rings}}
e25c13f86a914c3c38145e3c207d7ca4d045bcf0
Gingko Leaves
0
433
628
2025-07-16T19:23:24Z
Sharparam
284703
Add note on acquisition
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Materials|material]] found in {{BFF}} used in [[crafting]].
== Acquisition ==
Drops from several enemies in the game, as well as found on the ground in certain locations.
== Locations ==
{| class="wikitable"
! Amount !! Area !! Description !! Coordinates
|-
| 2 || [[Deluge]] || Found at the end of the platform before the bridge leading into the big rectangular structures with pillars. || {{coords|-4541|-1823|5552}}
|}
{{Navbox/Materials}}
[[Category:Materials]]
0fbff16a09a73af85c8ed1146f701144d7062005
Template:Weapons/CargoDeclare
10
448
660
2025-07-16T19:36:02Z
Sharparam
284703
Add support for Mk 0
wikitext
text/x-wiki
{{#cargo_declare:_table=Weapons
|name=String
|type=String
|speed=String
|damageType=String
|damageMk0Min=Integer
|damageMk0Max=Integer
|damageMk1Min=Integer
|damageMk1Max=Integer
|damageMk2Min=Integer
|damageMk2Max=Integer
|damageMk3Min=Integer
|damageMk3Max=Integer
|damageMk4Min=Integer
|damageMk4Max=Integer
|damageMk5Min=Integer
|damageMk5Max=Integer
}}
058226c206cdffeac8dd6c20fbd40d7a4b81f948
Template:Weapons/CargoStore
10
449
662
2025-07-16T19:36:27Z
Sharparam
284703
Add support for Mk 0
wikitext
text/x-wiki
<includeonly>{{#cargo_store:_table=Weapons
|name={{{name|}}}
|type={{{type|}}}
|speed={{{speed|}}}
|damageType={{{damageType|}}}
|damageMk0Min={{{damageMk0Min|}}}
|damageMk0Max={{{damageMk0Max|}}}
|damageMk1Min={{{damageMk1Min|}}}
|damageMk1Max={{{damageMk1Max|}}}
|damageMk2Min={{{damageMk2Min|}}}
|damageMk2Max={{{damageMk2Max|}}}
|damageMk3Min={{{damageMk3Min|}}}
|damageMk3Max={{{damageMk3Max|}}}
|damageMk4Min={{{damageMk4Min|}}}
|damageMk4Max={{{damageMk4Max|}}}
|damageMk5Min={{{damageMk5Min|}}}
|damageMk5Max={{{damageMk5Max|}}}
}}</includeonly><noinclude>{{#cargo_attach:table=Weapons}}</noinclude>
f0f50597b71007312dd924dfdbdaec0c577db10f
Divine Blessing
0
577
915
2025-07-16T19:42:01Z
Sharparam
284703
Created page with "{{Infobox/Ability | image = Divine Blessing.png | title = {{PAGENAME}} | Cost = 125 | Cooldown = 30 | Description = Restore 30% of your total [[HP]] and deal damage to all nearby [[Plague|plagued]] [[enemies]]. }} '''{{PAGENAME}}''' is a [[Weapons|weapon]] [[Abilities|ability]] in {{BFF}}. {{Navbox/Abilities}}"
wikitext
text/x-wiki
{{Infobox/Ability
| image = Divine Blessing.png
| title = {{PAGENAME}}
| Cost = 125
| Cooldown = 30
| Description = Restore 30% of your total [[HP]] and deal damage to all nearby [[Plague|plagued]] [[enemies]].
}}
'''{{PAGENAME}}''' is a [[Weapons|weapon]] [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
552de679ebb2751ab76780e73c8c534074b51109
Template:Navbox/Items
10
285
317
316
2025-07-16T19:44:12Z
Sharparam
284703
Add [[Ability Splinter]]
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = Essential
| list1 =
* [[Ability Splinter]]
* [[Mobius Blade]]
* [[Old Key]]
* [[Scanner]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
2673f0c1725f34950c7425ee96a8c3a415a40efc
318
317
2025-07-21T04:25:24Z
Sharparam
284703
Add [[Handler Echo]]
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = Essential
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Mobius Blade]]
* [[Old Key]]
* [[Scanner]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
0448d19159189da48bb14a046071effd62b3ef4d
Category:Essential items
14
418
598
2025-07-16T19:47:01Z
Sharparam
284703
Created page with "[[Category:Items]]"
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Category:Upgrade items
14
419
600
2025-07-16T19:56:59Z
Sharparam
284703
Created page with "[[Category:Items]]"
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Psychosis
0
376
514
2025-07-16T20:02:38Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}. == Overview == {{Quote |I've repeated the Completeness Protocol over 40 times now to no avail. No training can prepare a mind for this. All sense and reason are gone. The mental fortitude required to hold a coherent thought for longer than a heartbeat is soul-crushing. It feels like I am existing from one moment to the next. Picking up the remnants of déjà vu after déjà vu… }..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}.
== Overview ==
{{Quote
|I've repeated the Completeness Protocol over 40 times now to no avail. No training can prepare a mind for this. All sense and reason are gone. The mental fortitude required to hold a coherent thought for longer than a heartbeat is soul-crushing. It feels like I am existing from one moment to the next. Picking up the remnants of déjà vu after déjà vu…
}}
== Location ==
{{coords|-5130|-1039|5616}}
Found in [[Deluge|the Deluge]] area, near one of the [[Upgrade Splinter|upgrade splinters]] in the first big rectangular structure with pillars, near the first red lightpole. Use [[Scanner|the Scanner]] to more easily find the data log.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
b4998452a6a35bf04aeb60ea5d8c95c3edf9e497
Anomalous crystals
0
427
616
2025-07-16T20:18:17Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' are [[items]] that can be embedded into [[equipment]] ([[armor]] or [[weapons]] only) to improve their properties. == Overview == There are three "tiers" of crystals: '''[[Lesser Anomalous Crystal|lesser]]''', '''[[Anomalous Crystal|normal]]''', and '''[[Greater Anomalous Crystal|greater]]'''. Crystals can only be embedded into equipment by [[The Handler]]. Embedding a crystal into a slot destroys any crystal that is already occupying said slot, cau..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] that can be embedded into [[equipment]] ([[armor]] or [[weapons]] only) to improve their properties.
== Overview ==
There are three "tiers" of crystals: '''[[Lesser Anomalous Crystal|lesser]]''', '''[[Anomalous Crystal|normal]]''', and '''[[Greater Anomalous Crystal|greater]]'''.
Crystals can only be embedded into equipment by [[The Handler]]. Embedding a crystal into a slot destroys any crystal that is already occupying said slot, causing it to be lost forever.
{{Navbox/Items}}
[[Category:Anomalous crystals]]
5cef9dfbb687f0e77132dcb7450a11e973b25b95
Scanner
0
374
510
2025-07-16T20:22:09Z
Sharparam
284703
Add more info
wikitext
text/x-wiki
{{Infobox/Item
| image = Scanner.png
| title = {{PAGENAME}}
| Description = Captures and interprets data across hidden and abstract dimensions, revealing information that transcends conventional spatial and temporal limits, providing a comprehensive view of both visible and imperceptible phenomena.
}}
The '''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Overview ==
Activating the item scans the area around the player, revealing important interactables like [[data logs]] and ladders.
{{Navbox/Items}}
[[Category:Essential items]]
[[Category:Lore]]
72e26e842e217333080947ca9fd96dff00b2be1e
One-handed weapons
0
496
756
2025-07-16T20:32:03Z
Sharparam
284703
Add weapon list
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[Weapons|weapon]] in {{BFF}} that come in two variants: [[sharp]] and [[blunt]].
== List of one-handed weapons ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, speed=Speed, CONCAT('[[', damageType, ']]')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk0Min, '{{!}}', damageMk0Max, '{{))}}')=Damage (Mk 0), CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|where=type='one-handed'
|format=table
}}
{{Navbox/Weapons}}
[[Category:One-handed weapons]]
db05c537c888c3ecd32676dae4cbd9e3b79033c3
Weapons
0
465
694
2025-07-16T20:33:26Z
Sharparam
284703
Add Mk 0 damage column
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] in {{BFF}} used to engage in melee combat with [[enemies]].
== Upgrading ==
Weapons can be upgraded all the way to Mk 5 by speaking to [[The Handler]] and giving her the requisite materials.
Upgrading a weapon increases its damage as well as allowing you to embed more crystals into it to improve its properties further. Some weapons will also unlock passive bonuses or abilities when they are upgraded.
== List of weapons ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, CONCAT('[[', type, ']]')=Type, speed=Speed, CONCAT('[[', damageType, ']]')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk0Min, '{{!}}', damageMk0Max, '{{))}}')=Damage (Mk 0), CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|format=table
}}
{{Navbox/Weapons}}
627eeadeab2f527ee330ed3f5b806dcef85b45e8
Template:Infobox/Shield/doc
10
458
680
2025-07-21T00:03:40Z
Sharparam
284703
Created page with "== Examples == {{Infobox/Shield | image = Test shield.png | title = Test Shield | Weight = Light | Abilities = Shield Bash | Mk0_Sharp = 10 | Mk0_Blunt = 10 | Mk0_Technomancy = 10 | Mk1_Sharp = 20 | Mk1_Blunt = 20 | Mk1_Technomancy = 20 | Mk2_Sharp = 30 | Mk2_Blunt = 30 | Mk2_Technomancy = 30 | Mk3_Sharp = 40 | Mk3_Blunt = 40 | Mk3_Technomancy = 40 | Mk4_Sharp = 50 | Mk4_Blunt = 50 | Mk4_Technomancy = 50 | Mk5_Sharp = 60 | Mk5_Blunt = 60 | Mk5_Technomancy = 60 }} <synt..."
wikitext
text/x-wiki
== Examples ==
{{Infobox/Shield
| image = Test shield.png
| title = Test Shield
| Weight = Light
| Abilities = Shield Bash
| Mk0_Sharp = 10
| Mk0_Blunt = 10
| Mk0_Technomancy = 10
| Mk1_Sharp = 20
| Mk1_Blunt = 20
| Mk1_Technomancy = 20
| Mk2_Sharp = 30
| Mk2_Blunt = 30
| Mk2_Technomancy = 30
| Mk3_Sharp = 40
| Mk3_Blunt = 40
| Mk3_Technomancy = 40
| Mk4_Sharp = 50
| Mk4_Blunt = 50
| Mk4_Technomancy = 50
| Mk5_Sharp = 60
| Mk5_Blunt = 60
| Mk5_Technomancy = 60
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Shield
| image = Test shield.png
| title = Test Shield
| Weight = Light
| Abilities = Shield Bash
| Mk0_Sharp = 10
| Mk0_Blunt = 10
| Mk0_Technomancy = 10
| Mk1_Sharp = 20
| Mk1_Blunt = 20
| Mk1_Technomancy = 20
| Mk2_Sharp = 30
| Mk2_Blunt = 30
| Mk2_Technomancy = 30
| Mk3_Sharp = 40
| Mk3_Blunt = 40
| Mk3_Technomancy = 40
| Mk4_Sharp = 50
| Mk4_Blunt = 50
| Mk4_Technomancy = 50
| Mk5_Sharp = 60
| Mk5_Blunt = 60
| Mk5_Technomancy = 60
}}
</syntaxhighlight>
f660f4831abeb203edfc85fcc8225afbe28becd3
Wooden Shield
0
754
1168
2025-07-21T00:05:33Z
Sharparam
284703
Add details
wikitext
text/x-wiki
{{Infobox/Shield
| image = Wooden Shield.png
| title = {{PAGENAME}}
| Weight = Light
| Mk0_Sharp = 52.8
| Mk0_Blunt = 46.8
| Mk0_Technomancy = 7.2
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
{{Navbox/Shields}}
a25cde7cfde39f917e98c499b4c23d236886a94f
Template:Infobox/Shield
10
457
678
2025-07-21T00:10:28Z
Sharparam
284703
Add placeholders for Mk values
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=shield
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Weight,Passives,Abilities
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{#if:{{{Mk0_Sharp|}}}|{{{Mk0_Sharp}}}%|???}}
|Mk0_Blunt={{#if:{{{Mk0_Blunt|}}}|{{{Mk0_Blunt}}}%|???}}
|Mk0_Technomancy={{#if:{{{Mk0_Technomancy|}}}|{{{Mk0_Technomancy}}}%|???}}
|Mk1_Sharp={{#if:{{{Mk1_Sharp|}}}|{{{Mk1_Sharp}}}%|???}}
|Mk1_Blunt={{#if:{{{Mk1_Blunt|}}}|{{{Mk1_Blunt}}}%|???}}
|Mk1_Technomancy={{#if:{{{Mk1_Technomancy|}}}|{{{Mk1_Technomancy}}}%|???}}
|Mk2_Sharp={{#if:{{{Mk2_Sharp|}}}|{{{Mk2_Sharp}}}%|???}}
|Mk2_Blunt={{#if:{{{Mk2_Blunt|}}}|{{{Mk2_Blunt}}}%|???}}
|Mk2_Technomancy={{#if:{{{Mk2_Technomancy|}}}|{{{Mk2_Technomancy}}}%|???}}
|Mk3_Sharp={{#if:{{{Mk3_Sharp|}}}|{{{Mk3_Sharp}}}%|???}}
|Mk3_Blunt={{#if:{{{Mk3_Blunt|}}}|{{{Mk3_Blunt}}}%|???}}
|Mk3_Technomancy={{#if:{{{Mk3_Technomancy|}}}|{{{Mk3_Technomancy}}}%|???}}
|Mk4_Sharp={{#if:{{{Mk4_Sharp|}}}|{{{Mk4_Sharp}}}%|???}}
|Mk4_Blunt={{#if:{{{Mk4_Blunt|}}}|{{{Mk4_Blunt}}}%|???}}
|Mk4_Technomancy={{#if:{{{Mk4_Technomancy|}}}|{{{Mk4_Technomancy}}}%|???}}
|Mk5_Sharp={{#if:{{{Mk5_Sharp|}}}|{{{Mk5_Sharp}}}%|???}}
|Mk5_Blunt={{#if:{{{Mk5_Blunt|}}}|{{{Mk5_Blunt}}}%|???}}
|Mk5_Technomancy={{#if:{{{Mk5_Technomancy|}}}|{{{Mk5_Technomancy}}}%|???}}
}}{{#if:{{NAMESPACE}}||[[Category:Shields]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
879802ba38814822053b519e3543784bf8a6ee64
Shields
0
445
655
2025-07-21T01:31:34Z
Sharparam
284703
Add brief description
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] that can be used to protect the player against incoming [[damage]].
{{Navbox/Shields}}
[[Category:Shields]]
1e7147da72fc96843c2350072a5e579292f4c0ac
Fisherman
0
541
842
2025-07-21T01:43:20Z
Sharparam
284703
Add drop
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is an enemy in {{BFF}} that appears in the [[Deluge]] location.
== Drops ==
* [[Diver's Lungs Concoction]]
* [[Fractal Fungus]]
* [[Gingko Leaves]]
* [[Lesser Anomalous Crystal]]
* [[Lesser Restorative Fluid]]
* [[Ring of Burning Desire]]
* [[Sludge]]
* [[Upgrade Splinter]]
[[Category:Enemies]]
854a2903c300d816cf3a65b85c7bee9c7c9aeb6e
Librarian Overcoat
0
482
728
2025-07-21T01:55:58Z
Sharparam
284703
Created page with "{{Infobox/Armor | image = Librarian Overcoat.png | title = {{PAGENAME}} | Type = Chestguard | Set = Librarian | Weight = Light | Mk1_Sharp = 660 | Mk1_Blunt = 744 | Mk1_Technomancy = 1009 }} == Location == Dropped by "Librarian" enemies in [[Deluge|the Deluge]]? {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| image = Librarian Overcoat.png
| title = {{PAGENAME}}
| Type = Chestguard
| Set = Librarian
| Weight = Light
| Mk1_Sharp = 660
| Mk1_Blunt = 744
| Mk1_Technomancy = 1009
}}
== Location ==
Dropped by "Librarian" enemies in [[Deluge|the Deluge]]?
{{Navbox/Armor}}
ae4dc71e0b3fd31a0a4477632675eea80c6965d8
Librarian Trousers
0
488
740
2025-07-21T02:10:16Z
Sharparam
284703
Created page with "{{Infobox/Armor | image = Librarian Trousers.png | title = {{PAGENAME}} | Type = Legguard | Weight = Light | Set = Librarian | Mk1_Sharp = 456 | Mk1_Blunt = 516 | Mk1_Technomancy = 696 }} {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| image = Librarian Trousers.png
| title = {{PAGENAME}}
| Type = Legguard
| Weight = Light
| Set = Librarian
| Mk1_Sharp = 456
| Mk1_Blunt = 516
| Mk1_Technomancy = 696
}}
{{Navbox/Armor}}
1d0c2fa9e238497ee92524a75f41846d76113cd8
Improved Diver's Lungs Concoction
0
744
1148
2025-07-21T02:20:25Z
Sharparam
284703
Created page with "== Recipe == Obtained by defeating the many-legged creature in [[Deluge]]."
wikitext
text/x-wiki
== Recipe ==
Obtained by defeating the many-legged creature in [[Deluge]].
a1b23855f2d6d50d291ff7ec5da567ce7c83641d
Corrupted Cape
0
514
791
2025-07-21T02:27:42Z
Sharparam
284703
wikitext
text/x-wiki
{{Infobox/Cape
| image = Corrupted Cape.png
| title = {{PAGENAME}}
| Effect1 = +800 [[Sharp]] armor rating.
| Effect2 = +800 [[Blunt]] armor rating.
| Effect3 = +800 [[Technomancy]] armor rating.
}}
== Location ==
Dropped by the bigger knight guys ("Corrupted"?) wearing halberts in [[Deluge]].
{{Navbox/Capes}}
85092d24492b81865456f0c2ec6b4b43f2e6c927
Corrupted Cuirass
0
483
730
2025-07-21T02:28:57Z
Sharparam
284703
Created page with "{{Infobox/Armor | image = Corrupted Cuirass.png | title = {{PAGENAME}} | Type = Chestguard | Weight = Heavy | Mk2_Sharp = 1728 | Mk2_Blunt = 1488 | Mk2_Technomancy = 174 }} {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| image = Corrupted Cuirass.png
| title = {{PAGENAME}}
| Type = Chestguard
| Weight = Heavy
| Mk2_Sharp = 1728
| Mk2_Blunt = 1488
| Mk2_Technomancy = 174
}}
{{Navbox/Armor}}
183dddf62f3fe9d1345ac172c6970d381d73782b
Template:Armor/CargoDeclare
10
447
658
2025-07-21T02:30:31Z
Sharparam
284703
Add Mk 0
wikitext
text/x-wiki
{{#cargo_declare:_table=Armor
|name=String
|setname=String
|type=String
|weight=String
|sharpMk0=Integer
|bluntMk0=Integer
|technomancyMk0=Integer
|sharpMk1=Integer
|bluntMk1=Integer
|technomancyMk1=Integer
|sharpMk2=Integer
|bluntMk2=Integer
|technomancyMk2=Integer
|sharpMk3=Integer
|bluntMk3=Integer
|technomancyMk3=Integer
|sharpMk4=Integer
|bluntMk4=Integer
|technomancyMk4=Integer
|sharpMk5=Integer
|bluntMk5=Integer
|technomancyMk5=Integer
}}
338fa661fc066d90571ae8a2a2f747cb2c0d8f4f
Template:Armor/CargoStore
10
450
664
2025-07-21T02:31:15Z
Sharparam
284703
Add Mk 0
wikitext
text/x-wiki
<includeonly>{{#cargo_store:_table=Armor
|name={{{name|}}}
|setname={{{setname|}}}
|type={{{type|}}}
|weight={{{weight|}}}
|sharpMk0={{{sharpMk0|}}}
|bluntMk0={{{bluntMk0|}}}
|technomancyMk0={{{technomancyMk0|}}}
|sharpMk1={{{sharpMk1|}}}
|bluntMk1={{{bluntMk1|}}}
|technomancyMk1={{{technomancyMk1|}}}
|sharpMk2={{{sharpMk2|}}}
|bluntMk2={{{bluntMk2|}}}
|technomancyMk2={{{technomancyMk2|}}}
|sharpMk3={{{sharpMk3|}}}
|bluntMk3={{{bluntMk3|}}}
|technomancyMk3={{{technomancyMk3|}}}
|sharpMk4={{{sharpMk4|}}}
|bluntMk4={{{bluntMk4|}}}
|technomancyMk4={{{technomancyMk4|}}}
|sharpMk5={{{sharpMk5|}}}
|bluntMk5={{{bluntMk5|}}}
|technomancyMk5={{{technomancyMk5|}}}
}}</includeonly><noinclude>{{#cargo_attach:table=Armor}}</noinclude>
333780ac478dc35967062b394838e177b662daa9
Ring of Serpent
0
748
1156
2025-07-21T03:12:56Z
Sharparam
284703
Created page with "{{Infobox/Ring | image = Ring of Serpent.png | title = {{PAGENAME}} | Passives = [[Swift Reflexes]] | Effect1 = +2 [[Agility]] }} == Location == Near one of the underwater red lights in [[Deluge]]. {{Navbox/Rings}}"
wikitext
text/x-wiki
{{Infobox/Ring
| image = Ring of Serpent.png
| title = {{PAGENAME}}
| Passives = [[Swift Reflexes]]
| Effect1 = +2 [[Agility]]
}}
== Location ==
Near one of the underwater red lights in [[Deluge]].
{{Navbox/Rings}}
66cfb985c30744dba393ecfef89461918d2773f8
Techpriest Cape
0
515
793
2025-07-21T04:01:06Z
Sharparam
284703
Created page with "{{Infobox/Cape | image = Techpriest Cape | title = {{PAGENAME}} | Effect1 = +50 Max [[flux]] points. | Effect2 = +150 [[Flux]] leech rating. }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}} that can be worn by the player. == Location == {{coords|-4527|8973|9614}} Found in [[Asylum]]. After entering the first courtyard, climb the stairs on the right and jump onto the right ledge, then follow it backwards (towards the direction you entered from) and the item will b..."
wikitext
text/x-wiki
{{Infobox/Cape
| image = Techpriest Cape
| title = {{PAGENAME}}
| Effect1 = +50 Max [[flux]] points.
| Effect2 = +150 [[Flux]] leech rating.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}} that can be worn by the player.
== Location ==
{{coords|-4527|8973|9614}}
Found in [[Asylum]]. After entering the first courtyard, climb the stairs on the right and jump onto the right ledge, then follow it backwards (towards the direction you entered from) and the item will be on a corpse on the left.
== Trivia ==
* "Techpriest" in the name might be a reference to [https://wh40k.lexicanum.com/wiki/Tech-priest tech-priests] from [[w:Warhammer 40,000|Warhammer 40,000]].
{{Navbox/Capes}}
a7524062d33903459d69f5c7ae482dff8f0536c9
Tall Military Shield
0
751
1162
2025-07-21T04:07:58Z
Sharparam
284703
Created page with "{{Infobox/Shield | image = Tall Military Shield.png | title = {{PAGENAME}} | Weight = Heavy | Abilities = [[Improvised Fortification]] | Mk2_Sharp = 59.5 | Mk2_Blunt = 66.5 | Mk2_Technomancy = 52.5 }} '''{{PAGENAME}}''' is a [[Shields|shield]] that can be equipped by the player. It is the tall version of [[Military Shield|the Military Shield]]. == Location == {{coords|-4043|1327|1056}} Found in [[Asylum]]. After climbing a set of stars inside the first building after..."
wikitext
text/x-wiki
{{Infobox/Shield
| image = Tall Military Shield.png
| title = {{PAGENAME}}
| Weight = Heavy
| Abilities = [[Improvised Fortification]]
| Mk2_Sharp = 59.5
| Mk2_Blunt = 66.5
| Mk2_Technomancy = 52.5
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] that can be equipped by the player. It is the tall version of [[Military Shield|the Military Shield]].
== Location ==
{{coords|-4043|1327|1056}}
Found in [[Asylum]]. After climbing a set of stars inside the first building after the courtyard, the item is at the top on one of the catwalks.
{{Navbox/Shields}}
181aab1accc7978058774e9cab9eea6c94c3154c
Night Horror
0
377
516
2025-07-21T04:17:19Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] that can be found in {{BFF}}. == Overview == {{Quote |In the tower of [[Asylum|the asylum]], a chilling and unearthly wail reverbates through the walls—a sound that can only be described as the cry of a banshee. The eerie, mournful shrieks cut through the silence, hinting at a presence both agonizing and spectral. Among the abominations and horrors that define this place, one patient remains, but..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] that can be found in {{BFF}}.
== Overview ==
{{Quote
|In the tower of [[Asylum|the asylum]], a chilling and unearthly wail reverbates through the walls—a sound that can only be described as the cry of a banshee. The eerie, mournful shrieks cut through the silence, hinting at a presence both agonizing and spectral. Among the abominations and horrors that define this place, one patient remains, but it's difficult to truly say they have survived. This lone individual, if they can still be called such, exists in a state that blurs the line between life and death, their being a twisted echo of humanity amidst the torment. The banshee's cries seem to emanate from this tormented soul, a haunting reminder of the asylum's dark legacy and the incomprehensible suffering endured within its dark halls.
}}
== Location ==
{{coords|-3811|1199|9172}}
Found in [[Asylum|the Asylum]]. Located below a staircase after leaving the first building. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
fc7ee13e9ef0e02cd4a7722f0e91cb2e83028519
Sentinel
0
485
734
2025-07-21T04:43:45Z
Sharparam
284703
Created page with "{{Infobox/Armor set | image = Sentinel.png | title = {{PAGENAME}} | Helmet = Sentinel Helmet | Chestguard = Sentinel Chest | Legguard = Sentinel Legguard | Gauntlets = Sentinel Gauntlets }} '''{{PAGENAME}}''' is an [[Armor sets|armor set]] that can be found in {{BFF}}. == Location == {{coords|-3634|1305|9617}} The full set can be found on a corpse in [[Asylum|the Asylum]]. After reaching the top of the small spiral staircase, continue through the long corridor and ge..."
wikitext
text/x-wiki
{{Infobox/Armor set
| image = Sentinel.png
| title = {{PAGENAME}}
| Helmet = Sentinel Helmet
| Chestguard = Sentinel Chest
| Legguard = Sentinel Legguard
| Gauntlets = Sentinel Gauntlets
}}
'''{{PAGENAME}}''' is an [[Armor sets|armor set]] that can be found in {{BFF}}.
== Location ==
{{coords|-3634|1305|9617}}
The full set can be found on a corpse in [[Asylum|the Asylum]]. After reaching the top of the small spiral staircase, continue through the long corridor and get to the bottom of the next room. Walk through the doorway and hug the left wall to reach an area behind a wall with a corpse sitting in a corner holding the armor set and the [[Daggers]].
{{Navbox/Armor}}
c383d5b5ea00cce79216ed8915d5810d12cb993f
Armor
0
466
696
2025-07-21T04:47:25Z
Sharparam
284703
wikitext
text/x-wiki
'''{{PAGENAME}}''' is protective [[equipment]] that can be worn to increase defensive stats.
== List of armor ==
{{#cargo_query:table=Armor
|fields=CONCAT('[[', name, ']]')=Name, CONCAT('[[', type, ']]')=Type, weight=Weight
|format=table
}}
{{Navbox/Armor}}
9bd135cf1860c6152460f40d36e8fe2636fd7ef3
The Banshee
0
378
518
2025-07-21T05:37:26Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] that can be found in {{BFF}}. == Overview == {{Quote | The banshee's movements, dancing through [[Asylum|the asylum's]] decaying tower, are unsettingly precise, as if they were once part of a carefully honed combat style. Each anguished gesture and frenzied motion mirrors advanced fighting techniques, reminiscent of those taught at the highest levels of military training. The eerie choreography sugg..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] that can be found in {{BFF}}.
== Overview ==
{{Quote
| The banshee's movements, dancing through [[Asylum|the asylum's]] decaying tower, are unsettingly precise, as if they were once part of a carefully honed combat style. Each anguished gesture and frenzied motion mirrors advanced fighting techniques, reminiscent of those taught at the highest levels of military training. The eerie choreography suggests that the creature's wails are not merely cries of torment, but the remnants of a brutal experiment aimed at forging a living weapon. The movements, though now distorted and ghostly, hint at a once-formed discipline, twisted into a nightmarish mockery of the intended martial prowess. This spectral entity seems to embody the cruel ambition of those who sought to create a perfect instrument of war through unthinkable means.
}}
== Location ==
{{coords|-3943|1596|1532}}
Found in the center of a circular room, surrounded by chairs, in the big tower in [[Asylum|the asylum]]. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
0309dfabb2c1cb6950f037a68ebce98a2b67b20f
Template:Navbox/Items
10
285
319
318
2025-07-21T05:39:42Z
Sharparam
284703
Add [[Plagued Blood]]
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = Essential
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Mobius Blade]]
* [[Old Key]]
* [[Plagued Blood]]
* [[Scanner]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
b40f200532197c3923fcf2ffd79cb383740795bb
320
319
2025-07-23T01:17:51Z
Sharparam
284703
Add homunculus mirage and perk essence
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = Essential
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ddfce34a1183f816fb726793fbaee33e3e626bae
321
320
2025-07-23T04:06:46Z
Sharparam
284703
Add upgrade items
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = Essential
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group1.1 = [[Upgrade items|Upgrade]]
| list1.1 =
* [[Upgrade Splinter]]
* [[Upgrade Module]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
5d993314d5a6d93f05f9e71fae3e58357d179daf
Skullface Helmet
0
490
744
2025-07-21T05:47:59Z
Sharparam
284703
Created page with "{{Infobox/Armor | title = {{PAGENAME}} | image = Skullface Helmet.png | Type = Helmet | Weight = Light | Passives = [[Volatile Illusions]] | Mk5_Sharp = 692 | Mk5_Blunt = 692 | Mk5_Technomancy = 928 }} == Location == {{coords|-4063|1564|1686}} After reaching the room with a big circular elevator in the middle, look around the edges of the room for a bookshelf containing the helmet. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Skullface Helmet.png
| Type = Helmet
| Weight = Light
| Passives = [[Volatile Illusions]]
| Mk5_Sharp = 692
| Mk5_Blunt = 692
| Mk5_Technomancy = 928
}}
== Location ==
{{coords|-4063|1564|1686}}
After reaching the room with a big circular elevator in the middle, look around the edges of the room for a bookshelf containing the helmet.
{{Navbox/Armor}}
06db38be9569d6ea522dedf56d2264708ad17817
Vengeance
0
486
736
2025-07-21T05:51:00Z
Sharparam
284703
Created page with "{{Infobox/Armor set | title = {{PAGENAME}} | image = Vengeance.png | Helmet = Vengeance Helmet | Chestguard = Vengeance Cuirass | Legguard = Vengeance Legs | Gauntlets = Vengeance Gauntlets }} '''{{PAGENAME}}''' is an [[Armor sets|armor set]] found in {{BFF}}. == Location == {{coords|-3925|1676|9471}} Found on a corpse in the shortcut area leading to the big tower. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor set
| title = {{PAGENAME}}
| image = Vengeance.png
| Helmet = Vengeance Helmet
| Chestguard = Vengeance Cuirass
| Legguard = Vengeance Legs
| Gauntlets = Vengeance Gauntlets
}}
'''{{PAGENAME}}''' is an [[Armor sets|armor set]] found in {{BFF}}.
== Location ==
{{coords|-3925|1676|9471}}
Found on a corpse in the shortcut area leading to the big tower.
{{Navbox/Armor}}
37e805d19347a1c48db878ae9dc7e86a5905fb7b
Hellicar's Maxims
0
379
520
2025-07-21T06:09:02Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' are [[lore]] [[documents]] that can be found in {{BFF}}. == Acquisition == Drops from [[enemies]] in the game. * Asylum enemy with cape and sword+shield. {{Navbox/Documents}} [[Category:Lore]] [[Category:Documents]]"
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[documents]] that can be found in {{BFF}}.
== Acquisition ==
Drops from [[enemies]] in the game.
* Asylum enemy with cape and sword+shield.
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
9e54fe19f15f8d8dce8dd560ec5bc7a0f7a98dab
Category:Bosses
14
540
840
2025-07-21T06:25:38Z
Sharparam
284703
Created page with "[[Category:Enemies]]"
wikitext
text/x-wiki
[[Category:Enemies]]
d3da306a1b523dea15853a2b661da0200bf2f201
Enemies
0
537
834
2025-07-21T06:26:56Z
Sharparam
284703
Created page with "{{Navbox/Enemies}}"
wikitext
text/x-wiki
{{Navbox/Enemies}}
833889e0d1b529dbf02a0a7b4ded350913eaaadd
Bosses
0
539
838
2025-07-21T06:28:40Z
Sharparam
284703
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful, unique [[enemies]] that do not respawn and typically grant bigger rewards when defeated.
{{Navbox/Bosses}}
0c3e8dc2475799e24d9fb25b0d80bf435d40e02a
Template:Infobox/Boss
10
461
686
2025-07-21T06:50:54Z
Sharparam
284703
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind = boss
| sep=,
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| title = {{{title|{{PAGENAME}}}}}
| sections = Basic Info, Stats
| Stats = HP, SharpResist, BluntResist, TechnomancyResist
| SharpResist_label = [[File:Sharp outlined.png|20px|link=Sharp]] [[Sharp]] resistance
| BluntResist_label = [[File:Blunt outlined.png|20px|link=Blunt]] [[Blunt]] resistance
| TechnomancyResist_label = [[File:Technomancy outlined.png|20px|link=Technomancy]] [[Technomancy]] resistance
| SharpResist = {{#if:{{{SharpResist|}}}|{{{SharpResist}}}%}}
| BluntResist = {{#if:{{{BluntResist|}}}|{{{BluntResist}}}%}}
| TechnomancyResist = {{#if:{{{TechnomancyResist|}}}|{{{TechnomancyResist}}}%}}
}}{{#if:{{NAMESPACE}}||[[Category:Bosses]]}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]
</noinclude>
64710a105198d7712f12bdaeab6e515bd71f2fe8
Template:Navbox/Data logs
10
290
350
349
2025-07-21T16:25:33Z
Sharparam
284703
Add [[Shadows in the Courtyard]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
f20790d1177712318ffb0c575d91690d98c09f19
351
350
2025-07-23T01:24:56Z
Sharparam
284703
Add [[Inhabitants]] and note on ordering
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
8805c049301dbd9643cf641fef2da91d8afdfbf0
352
351
2025-07-23T04:47:22Z
Sharparam
284703
Add [[Serpentine Visions]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
8e02ca819e48ceaeec301d132d06e960ed6923a9
353
352
2025-07-23T06:03:21Z
Sharparam
284703
Add [[Shifting Sands]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
b969662647d22a6cc9072e811cb3f2f163b91464
354
353
2025-07-23T09:35:40Z
Sharparam
284703
Add [[Call of the Void]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
125ee0dcc36ec7294986a579187b61c57ec19bd5
355
354
2025-07-23T10:15:56Z
Sharparam
284703
Add [[Umbral City]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
7c563198274471604afdcb166842cd0df6f210b0
356
355
2025-07-23T10:25:33Z
Sharparam
284703
Add [[Intercepted Transmission]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ebf1841010ec3a6aa0d5dc427bd59a5986403681
357
356
2025-07-23T13:05:10Z
Sharparam
284703
Add [[Desert Dream]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
1496e77efafb4db0cbdd7f82f39fcdf8abf52d0f
Shadows in the Courtyard
0
380
522
2025-07-21T16:32:22Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
| There's a radial pattern in [[Blok 6147|this Blok]]. A heavily pedestrian zone. The people living here must have had a rather communal spirit. I can't tell if it's just my mind, but I can hear the echoes of children shouting. The ring of a school bell. The creek of a rusty gate opening and closing in a morning ritual. I imagine some of the views here are rather stunning.
}}
== Location ==
{{coords|-1016|-3857|2319}}
Found in [[Blok 6147]], on a round balcony overlooking the central hub.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
3ea9546e3cf140db20981b41b9f9f6e2f674c210
Module:Check for unknown parameters
828
614
965
2025-07-22T11:58:12Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- This module may be used to compare the arguments passed to the parent
-- with a list of arguments, returning a specified result if an argument is
-- not on the list
local p = {}
local function trim(s)
return s:match('^%s*(.-)%s*$')
end
local function isnotempty(s)
return s and trim(s) ~= ''
end
function p.check (frame)
local args = frame.args
local pargs = frame:getParent().args
local ignoreblank = isnotempty(frame.args['ignoreblank'])
local checkpos = isnotempty(frame.args['checkpositional'])
local knownargs = {}
local unknown = frame.args['unknown'] or 'Found _VALUE_, '
local preview = frame.args['preview']
local res = {}
local regexps = {}
local comments = {}
local commentstr = ''
local ispreview = frame:preprocess( "{{REVISIONID}}" ) == "" and 1 or 0
-- create the list of known args, regular expressions, and the return string
for k, v in pairs(args) do
if type(k) == 'number' then
v = trim(v)
knownargs[v] = 1
elseif k:find('^regexp[1-9][0-9]*$') then
table.insert(regexps, '^' .. v .. '$')
end
end
if isnotempty(preview) then
preview = '<div class="hatnote" style="color:red"><strong>Warning:</strong> ' .. preview .. ' (this message is shown only in preview).</div>'
elseif preview == nil then
preview = unknown
end
if ispreview == 1 then
unknown = preview
ignoreblank = false
end
-- adds one result to the output tables
local function addresult(k)
if k == '' then
-- Fix odd bug for | = which gets stripped to the empty string and
-- breaks category links
k = ' '
end
local r = unknown:gsub('_VALUE_', k)
table.insert(res, r)
table.insert(comments, '"' .. k .. '"')
end
-- loop over the parent args, and make sure they are on the list
for k, v in pairs(pargs) do
if type(k) == 'string' and knownargs[k] == nil then
local knownflag = false
for i, regexp in ipairs(regexps) do
if mw.ustring.match(k, regexp) then
knownflag = true
break
end
end
if not knownflag and ( not ignoreblank or isnotempty(v) ) then
k = mw.ustring.gsub(k, '[^%w%-_ ]', '?')
addresult(k)
end
elseif checkpos and
type(k) == 'number' and
knownargs[tostring(k)] == nil and
( not ignoreblank or isnotempty(v) )
then
addresult(k)
end
end
if #comments > 0 then
commentstr = '<!-- Module:Check for unknown parameters results: ' ..
table.concat(comments, ', ') .. '-->'
end
return table.concat(res) .. commentstr
end
return p
90cb45a6cbe02f0d73cbfdec8233df899b000e3d
Agility
0
711
1088
2025-07-22T13:14:28Z
Sharparam
284703
Add missing category
wikitext
text/x-wiki
'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects stats related to critical chance, stamina, speed, and boss resistance to arrows.
== Overview ==
Critical chance and melee swing speed both have a hard cap at 100. The hard caps for other stats can be seen in the table when their increment amount drops to zero.
<!--<div class="noresize">-->
{| class="wikitable hover-highlight mw-collapsible mw-collapsed sortable sticky-header-multi" style="text-align: right;"
|-
! class="unsortable" scope="col" rowspan="2" | Agility
! class="unsortable" scope="col" rowspan="2" | Crit chance
! class="unsortable" scope="col" rowspan="2" | Stamina
! class="unsortable" scope="col" rowspan="2" | Stam delay
! class="unsortable" scope="col" rowspan="2" | Move speed
! class="unsortable" scope="col" rowspan="2" | Melee swing speed
! class="unsortable" scope="col" rowspan="2" | Range wep draw spd pen
! class="unsortable" scope="col" rowspan="2" | Boss arrow res reduction
! class="unsortable" scope="col" colspan="7" | Increments
|-
! class="unsortable" scope="col" | Crit chance
! class="unsortable" scope="col" | Stamina
! class="unsortable" scope="col" | Stam delay
! class="unsortable" scope="col" | Move speed
! class="unsortable" scope="col" | Melee swing speed
! class="unsortable" scope="col" | Range wep draw spd pen
! class="unsortable" scope="col" | Boss arrow res reduction
|-
| 0 || 0.00% || 105 || 1.90 || 100.00% || 100.0% || 25.00% || 0% || 0.00% || 0 || 0.00 || 0.00% || 0.0% || 0.00% || 0%
|-
| 1 || 0.00% || 105 || 1.90 || 100.00% || 100.0% || 23.89% || 1% || 0.00% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 2 || 0.25% || 105 || 1.90 || 100.00% || 100.0% || 22.78% || 2% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 3 || 0.50% || 105 || 1.90 || 100.00% || 100.0% || 21.67% || 3% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 4 || 0.75% || 105 || 1.90 || 100.00% || 100.0% || 20.56% || 4% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 5 || 1.00% || 105 || 1.90 || 100.00% || 100.0% || 19.45% || 5% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 6 || 1.50% || 107 || 1.89 || 100.00% || 100.0% || 18.34% || 6% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 7 || 2.00% || 109 || 1.88 || 100.00% || 100.0% || 17.23% || 7% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 8 || 2.50% || 111 || 1.87 || 100.00% || 100.0% || 16.12% || 8% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 9 || 3.00% || 113 || 1.86 || 100.00% || 100.0% || 15.01% || 9% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 10 || 3.50% || 115 || 1.85 || 100.00% || 100.0% || 13.90% || 10% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 11 || 4.10% || 117 || 1.84 || 100.00% || 100.0% || 12.79% || 11% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 12 || 4.70% || 119 || 1.83 || 100.00% || 100.0% || 11.68% || 12% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 13 || 5.30% || 121 || 1.82 || 100.00% || 100.0% || 10.57% || 13% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 14 || 5.90% || 123 || 1.81 || 100.00% || 100.0% || 9.46% || 14% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 15 || 6.50% || 125 || 1.80 || 100.00% || 100.0% || 8.35% || 15% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 16 || 9.07% || 127 || 1.79 || 100.17% || 100.5% || 7.24% || 16% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 17 || 11.64% || 129 || 1.78 || 100.34% || 101.0% || 6.13% || 17% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 18 || 14.21% || 131 || 1.77 || 100.51% || 101.5% || 5.02% || 18% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 19 || 16.78% || 133 || 1.76 || 100.68% || 102.0% || 3.91% || 19% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 20 || 19.35% || 135 || 1.75 || 100.85% || 102.5% || 2.80% || 20% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 21 || 21.92% || 137 || 1.74 || 101.02% || 103.0% || 1.69% || 21% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 22 || 24.49% || 139 || 1.73 || 101.19% || 103.5% || 0.58% || 22% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 23 || 27.06% || 141 || 1.72 || 101.36% || 104.0% || -0.53% || 23% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 24 || 29.63% || 143 || 1.71 || 101.53% || 104.5% || -1.64% || 24% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 25 || 32.20% || 145 || 1.70 || 101.70% || 105.0% || -2.75% || 25% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 26 || 34.77% || 147 || 1.69 || 101.87% || 105.5% || -3.86% || 26% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 27 || 37.34% || 149 || 1.68 || 102.04% || 106.0% || -4.97% || 27% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 28 || 39.91% || 151 || 1.67 || 102.21% || 106.5% || -6.08% || 28% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 29 || 42.48% || 153 || 1.66 || 102.38% || 107.0% || -7.19% || 29% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 30 || 45.05% || 155 || 1.65 || 102.55% || 107.5% || -8.30% || 30% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 31 || 46.05% || 157 || 1.64 || 102.72% || 108.0% || -9.41% || 31% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 32 || 47.05% || 159 || 1.63 || 102.89% || 108.5% || -10.52% || 32% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 33 || 48.05% || 161 || 1.62 || 103.06% || 109.0% || -11.63% || 33% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 34 || 49.05% || 163 || 1.61 || 103.23% || 109.5% || -12.74% || 34% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 35 || 50.05% || 165 || 1.60 || 103.40% || 110.0% || -13.85% || 35% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 36 || 51.05% || 167 || 1.59 || 103.57% || 110.5% || -14.96% || 36% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 37 || 52.05% || 169 || 1.58 || 103.74% || 111.0% || -16.07% || 37% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 38 || 53.05% || 171 || 1.57 || 103.91% || 111.5% || -17.18% || 38% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 39 || 54.05% || 173 || 1.56 || 104.08% || 112.0% || -18.29% || 39% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 40 || 55.05% || 175 || 1.55 || 104.25% || 112.5% || -19.40% || 40% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 41 || 56.05% || 177 || 1.54 || 104.42% || 113.0% || -20.51% || 41% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 42 || 57.05% || 179 || 1.53 || 104.59% || 113.5% || -21.62% || 42% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 43 || 58.05% || 181 || 1.52 || 104.76% || 114.0% || -22.73% || 43% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 44 || 59.05% || 183 || 1.51 || 104.93% || 114.5% || -23.84% || 44% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 45 || 60.05% || 185 || 1.50 || 105.10% || 115.0% || -24.95% || 45% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 46 || 61.05% || 186 || 1.50 || 105.24% || 115.5% || -24.95% || 46% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 47 || 62.05% || 187 || 1.50 || 105.38% || 116.0% || -24.95% || 47% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 48 || 63.05% || 188 || 1.50 || 105.52% || 116.5% || -24.95% || 48% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 49 || 64.05% || 189 || 1.50 || 105.66% || 117.0% || -24.95% || 49% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 50 || 65.05% || 190 || 1.50 || 105.80% || 117.5% || -24.95% || 50% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 51 || 65.45% || 191 || 1.50 || 105.94% || 117.7% || -24.95% || 51% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 52 || 65.85% || 192 || 1.50 || 106.08% || 117.9% || -24.95% || 52% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 53 || 66.25% || 193 || 1.50 || 106.22% || 118.1% || -24.95% || 53% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 54 || 66.65% || 194 || 1.50 || 106.36% || 118.3% || -24.95% || 54% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 55 || 67.05% || 195 || 1.50 || 106.50% || 118.5% || -24.95% || 55% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 56 || 67.45% || 196 || 1.50 || 106.64% || 118.7% || -24.95% || 56% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 57 || 67.85% || 197 || 1.50 || 106.78% || 118.9% || -24.95% || 57% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 58 || 68.25% || 198 || 1.50 || 106.92% || 119.1% || -24.95% || 58% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 59 || 68.65% || 199 || 1.50 || 107.06% || 119.3% || -24.95% || 59% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 60 || 69.05% || 200 || 1.50 || 107.20% || 119.5% || -24.95% || 60% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 61 || 69.45% || 201 || 1.50 || 107.34% || 119.7% || -24.95% || 61% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 62 || 69.85% || 202 || 1.50 || 107.48% || 119.9% || -24.95% || 62% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 63 || 70.25% || 203 || 1.50 || 107.62% || 120.1% || -24.95% || 63% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 64 || 70.65% || 204 || 1.50 || 107.76% || 120.3% || -24.95% || 64% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 65 || 71.05% || 205 || 1.50 || 107.90% || 120.5% || -24.95% || 65% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 66 || 71.45% || 206 || 1.50 || 108.04% || 120.7% || -24.95% || 66% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 67 || 71.85% || 207 || 1.50 || 108.18% || 120.9% || -24.95% || 67% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 68 || 72.25% || 208 || 1.50 || 108.32% || 121.1% || -24.95% || 68% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 69 || 72.65% || 209 || 1.50 || 108.46% || 121.3% || -24.95% || 69% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 70 || 73.05% || 210 || 1.50 || 108.60% || 121.5% || -24.95% || 70% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 71 || 73.45% || 211 || 1.50 || 108.74% || 121.7% || -24.95% || 71% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 72 || 73.85% || 212 || 1.50 || 108.88% || 121.9% || -24.95% || 72% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 73 || 74.25% || 213 || 1.50 || 109.02% || 122.1% || -24.95% || 73% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 74 || 74.65% || 214 || 1.50 || 109.16% || 122.3% || -24.95% || 74% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 75 || 75.05% || 215 || 1.50 || 109.30% || 122.5% || -24.95% || 75% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 76 || 75.25% || 216 || 1.50 || 109.44% || 122.6% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 77 || 75.45% || 217 || 1.50 || 109.58% || 122.7% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 78 || 75.65% || 218 || 1.50 || 109.72% || 122.8% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 79 || 75.85% || 219 || 1.50 || 109.86% || 122.9% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 80 || 76.05% || 220 || 1.50 || 110.00% || 123.0% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 81 || 76.25% || 221 || 1.50 || 110.00% || 123.1% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 82 || 76.45% || 222 || 1.50 || 110.00% || 123.2% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 83 || 76.65% || 223 || 1.50 || 110.00% || 123.3% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 84 || 76.85% || 224 || 1.50 || 110.00% || 123.4% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 85 || 77.05% || 225 || 1.50 || 110.00% || 123.5% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 86 || 77.25% || 226 || 1.50 || 110.00% || 123.6% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 87 || 77.45% || 227 || 1.50 || 110.00% || 123.7% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 88 || 77.65% || 228 || 1.50 || 110.00% || 123.8% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 89 || 77.85% || 229 || 1.50 || 110.00% || 123.9% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 90 || 78.05% || 230 || 1.50 || 110.00% || 124.0% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 91 || 78.25% || 231 || 1.50 || 110.00% || 124.1% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 92 || 78.45% || 232 || 1.50 || 110.00% || 124.2% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 93 || 78.65% || 233 || 1.50 || 110.00% || 124.3% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 94 || 78.85% || 234 || 1.50 || 110.00% || 124.4% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 95 || 79.05% || 235 || 1.50 || 110.00% || 124.5% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 96 || 79.25% || 236 || 1.50 || 110.00% || 124.6% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 97 || 79.45% || 237 || 1.50 || 110.00% || 124.7% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 98 || 79.65% || 238 || 1.50 || 110.00% || 124.8% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 99 || 79.85% || 239 || 1.50 || 110.00% || 124.9% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 100 || 80.05% || 240 || 1.50 || 110.00% || 125.0% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|}
<!--</div>-->
[[Category:Attributes]]
7a701b76e512860658a8b6ad71e4474cbf3409ce
Category:Attributes
14
708
1082
2025-07-22T13:14:41Z
Sharparam
284703
Created page with "[[Category:Game mechanics]]"
wikitext
text/x-wiki
[[Category:Game mechanics]]
f2739a7f6d15068b5f220f8cbb0a1aa293521862
Strength
0
710
1086
2025-07-22T13:16:16Z
Sharparam
284703
Improve table
wikitext
text/x-wiki
'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects weapon damage and max weight.
== Overview ==
Strength affects bonus weapon damage, as well as the max weight which affects encumbrance.
The gain to max weight is {{val|450|u=g}} for every attribute point until 45, which is the last to give the increment. Every additional level into strength after that will not increase max weight, so it has a hard cap of {{val|40.5|u=kg}}.
The gain to bonus weapon damage is always 10.8%, but going past 92 shows the total bonus damage as always being 1%. It is unclear if this is just a visual bug or if the bonus damage actually does drop down to 1%.
{| class="wikitable sortable hover-highlight sticky-header-multi mw-collapsible mw-collapsed" style="text-align: right;"
|-
! class="unsortable" scope="col" rowspan="2" | Strength
! class="unsortable" scope="col" rowspan="2" | +Weapon DMG
! class="unsortable" scope="col" rowspan="2" | Max weight (g)
! class="unsortable" scope="col" colspan="2" | Increments
|-
! class="unsortable" scope="col" | +Weapon DMG
! class="unsortable" scope="col" | Max weight (g)
|-
| 0 || 0.0% || {{fnum|20250}} || 0.0% || 0
|-
| 1 || 10.8% || {{fnum|20700}} || 10.8% || 450
|-
| 2 || 21.6% || {{fnum|21150}} || 10.8% || 450
|-
| 3 || 32.4% || {{fnum|21600}} || 10.8% || 450
|-
| 4 || 43.2% || {{fnum|22050}} || 10.8% || 450
|-
| 5 || 54.0% || {{fnum|22500}} || 10.8% || 450
|-
| 6 || 64.8% || {{fnum|22950}} || 10.8% || 450
|-
| 7 || 75.6% || {{fnum|23400}} || 10.8% || 450
|-
| 8 || 86.4% || {{fnum|23850}} || 10.8% || 450
|-
| 9 || 97.2% || {{fnum|24300}} || 10.8% || 450
|-
| 10 || 108.0% || {{fnum|24750}} || 10.8% || 450
|-
| 11 || 118.8% || {{fnum|25200}} || 10.8% || 450
|-
| 12 || 129.6% || {{fnum|25650}} || 10.8% || 450
|-
| 13 || 140.4% || {{fnum|26100}} || 10.8% || 450
|-
| 14 || 151.2% || {{fnum|26550}} || 10.8% || 450
|-
| 15 || 162.0% || {{fnum|27000}} || 10.8% || 450
|-
| 16 || 172.8% || {{fnum|27450}} || 10.8% || 450
|-
| 17 || 183.6% || {{fnum|27900}} || 10.8% || 450
|-
| 18 || 194.4% || {{fnum|28350}} || 10.8% || 450
|-
| 19 || 205.2% || {{fnum|28800}} || 10.8% || 450
|-
| 20 || 216.0% || {{fnum|29250}} || 10.8% || 450
|-
| 21 || 226.8% || {{fnum|29700}} || 10.8% || 450
|-
| 22 || 237.6% || {{fnum|30150}} || 10.8% || 450
|-
| 23 || 248.4% || {{fnum|30600}} || 10.8% || 450
|-
| 24 || 259.2% || {{fnum|31050}} || 10.8% || 450
|-
| 25 || 270.0% || {{fnum|31500}} || 10.8% || 450
|-
| 26 || 280.8% || {{fnum|31950}} || 10.8% || 450
|-
| 27 || 291.6% || {{fnum|32400}} || 10.8% || 450
|-
| 28 || 302.4% || {{fnum|32850}} || 10.8% || 450
|-
| 29 || 313.2% || {{fnum|33300}} || 10.8% || 450
|-
| 30 || 324.0% || {{fnum|33750}} || 10.8% || 450
|-
| 31 || 334.8% || {{fnum|34200}} || 10.8% || 450
|-
| 32 || 345.6% || {{fnum|34650}} || 10.8% || 450
|-
| 33 || 356.4% || {{fnum|35100}} || 10.8% || 450
|-
| 34 || 367.2% || {{fnum|35550}} || 10.8% || 450
|-
| 35 || 378.0% || {{fnum|36000}} || 10.8% || 450
|-
| 36 || 388.8% || {{fnum|36450}} || 10.8% || 450
|-
| 37 || 399.6% || {{fnum|36900}} || 10.8% || 450
|-
| 38 || 410.4% || {{fnum|37350}} || 10.8% || 450
|-
| 39 || 421.2% || {{fnum|37800}} || 10.8% || 450
|-
| 40 || 432.0% || {{fnum|38250}} || 10.8% || 450
|-
| 41 || 442.8% || {{fnum|38700}} || 10.8% || 450
|-
| 42 || 453.6% || {{fnum|39150}} || 10.8% || 450
|-
| 43 || 464.4% || {{fnum|39600}} || 10.8% || 450
|-
| 44 || 475.2% || {{fnum|40050}} || 10.8% || 450
|-
| 45 || 486.0% || {{fnum|40500}} || 10.8% || 450
|-
| 46 || 496.8% || {{fnum|40500}} || 10.8% || 0
|-
| 47 || 507.6% || {{fnum|40500}} || 10.8% || 0
|-
| 48 || 518.4% || {{fnum|40500}} || 10.8% || 0
|-
| 49 || 529.2% || {{fnum|40500}} || 10.8% || 0
|-
| 50 || 540.0% || {{fnum|40500}} || 10.8% || 0
|-
| 51 || 550.8% || {{fnum|40500}} || 10.8% || 0
|-
| 52 || 561.6% || {{fnum|40500}} || 10.8% || 0
|-
| 53 || 572.4% || {{fnum|40500}} || 10.8% || 0
|-
| 54 || 583.2% || {{fnum|40500}} || 10.8% || 0
|-
| 55 || 594.0% || {{fnum|40500}} || 10.8% || 0
|-
| 56 || 604.8% || {{fnum|40500}} || 10.8% || 0
|-
| 57 || 615.6% || {{fnum|40500}} || 10.8% || 0
|-
| 58 || 626.4% || {{fnum|40500}} || 10.8% || 0
|-
| 59 || 637.2% || {{fnum|40500}} || 10.8% || 0
|-
| 60 || 648.0% || {{fnum|40500}} || 10.8% || 0
|-
| 61 || 658.8% || {{fnum|40500}} || 10.8% || 0
|-
| 62 || 669.6% || {{fnum|40500}} || 10.8% || 0
|-
| 63 || 680.4% || {{fnum|40500}} || 10.8% || 0
|-
| 64 || 691.2% || {{fnum|40500}} || 10.8% || 0
|-
| 65 || 702.0% || {{fnum|40500}} || 10.8% || 0
|-
| 66 || 712.8% || {{fnum|40500}} || 10.8% || 0
|-
| 67 || 723.6% || {{fnum|40500}} || 10.8% || 0
|-
| 68 || 734.4% || {{fnum|40500}} || 10.8% || 0
|-
| 69 || 745.2% || {{fnum|40500}} || 10.8% || 0
|-
| 70 || 756.0% || {{fnum|40500}} || 10.8% || 0
|-
| 71 || 766.8% || {{fnum|40500}} || 10.8% || 0
|-
| 72 || 777.6% || {{fnum|40500}} || 10.8% || 0
|-
| 73 || 788.4% || {{fnum|40500}} || 10.8% || 0
|-
| 74 || 799.2% || {{fnum|40500}} || 10.8% || 0
|-
| 75 || 810.0% || {{fnum|40500}} || 10.8% || 0
|-
| 76 || 820.8% || {{fnum|40500}} || 10.8% || 0
|-
| 77 || 831.6% || {{fnum|40500}} || 10.8% || 0
|-
| 78 || 842.4% || {{fnum|40500}} || 10.8% || 0
|-
| 79 || 853.2% || {{fnum|40500}} || 10.8% || 0
|-
| 80 || 864.0% || {{fnum|40500}} || 10.8% || 0
|-
| 81 || 874.8% || {{fnum|40500}} || 10.8% || 0
|-
| 82 || 885.6% || {{fnum|40500}} || 10.8% || 0
|-
| 83 || 896.4% || {{fnum|40500}} || 10.8% || 0
|-
| 84 || 907.2% || {{fnum|40500}} || 10.8% || 0
|-
| 85 || 918.0% || {{fnum|40500}} || 10.8% || 0
|-
| 86 || 928.8% || {{fnum|40500}} || 10.8% || 0
|-
| 87 || 939.6% || {{fnum|40500}} || 10.8% || 0
|-
| 88 || 950.4% || {{fnum|40500}} || 10.8% || 0
|-
| 89 || 961.2% || {{fnum|40500}} || 10.8% || 0
|-
| 90 || 972.0% || {{fnum|40500}} || 10.8% || 0
|-
| 91 || 982.8% || {{fnum|40500}} || 10.8% || 0
|-
| 92 || 993.6% || {{fnum|40500}} || 10.8% || 0
|}
[[Category:Attributes]]
acf936b03bf018cd91d4c8f8790137535cf71c2d
Attributes
0
712
1090
2025-07-22T13:19:55Z
Sharparam
284703
Link to level
wikitext
text/x-wiki
'''{{PAGENAME}}''' determine the player's [[stats]].
== Overview ==
Each time the player [[Level|levels up]], they get two points to spend on one of the four attributes.
== Strength ==
{{main|Strength}}
== Agility ==
{{main|Agility}}
== Intelligence ==
{{main|Intelligence}}
== Constitution ==
{{main|Constitution}}
[[Category:Attributes]]
9e68b22348fa67fdf1237f31b0043c8996b44821
Blok 6174
0
741
1142
2025-07-23T00:15:54Z
Sharparam
284703
Redirected page to [[Blok 6147]]
wikitext
text/x-wiki
#REDIRECT [[Blok 6147]]
3ee370bab2292ee469f53ad5d06af212bbb3db85
Template:Infobox/Item
10
417
596
2025-07-23T00:44:01Z
Sharparam
284703
Use alternative method for description
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind=item
| sep=,
| image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=DescriptionSection
| DescriptionSection=Description
| DescriptionSection_label=Description
| Description_nolabel=yes
}}{{#if:{{NAMESPACE}}||[[Category:Items]]}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]</noinclude>
5d4929aef36fffdaea5150152baf68fb562131a0
Silicon Visage
0
543
846
2025-07-23T00:59:56Z
Sharparam
284703
Created page with "{{Infobox/Boss | image = Silicon Visage.png | SharpResist = 15 | BluntResist = 16 | TechnomancyResist = 55 }} '''{{PAGENAME}}''' is an optional [[Bosses|boss]] [[Enemies|enemy]] in {{BFF}}. == Location == {{coords|9307|2902|1628}} (approximate) Located in [[Upper Blocks]]. == Drops == * [[Upgrade Module]] * [[Unstable Perk Essence]] {{Navbox/Bosses}}"
wikitext
text/x-wiki
{{Infobox/Boss
| image = Silicon Visage.png
| SharpResist = 15
| BluntResist = 16
| TechnomancyResist = 55
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] [[Enemies|enemy]] in {{BFF}}.
== Location ==
{{coords|9307|2902|1628}} (approximate)
Located in [[Upper Blocks]].
== Drops ==
* [[Upgrade Module]]
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
773d7fa0e470181a1ad1ada63a49044d0679caf7
Homunculus Mirage
0
423
608
2025-07-23T01:18:18Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
{{Infobox/Item
| tabs=Normal,Husk
| Normal_title = Homunculus Mirage
| Husk_title = Humunculus Mirage Husk
| images = [[File:Homunculus Mirage.png|300px]],[[File:Homunculus Mirage Husk.png|300px]]
| Normal_Description = The Homunculus triggers its ability only when your vital signs have ceased – reassembling your body on a molecular level elsewhere while keeping your consciousness intact, allowing for seamless and instantaneous relocation.
| Husk_Description = The husk of the Homunculus stores your current state and consciousness. Return at the Homunculus to combine the two again, allowing you to place the Homunculus elsewhere.
}}
{{Navbox/Items}}
[[Category:Essential items]]
8fb75994fa6cda97b1ebe8cfd760652188977f94
Inhabitants
0
381
524
2025-07-23T01:23:54Z
Sharparam
284703
Created page with "{{stub}} {{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}. == Overview == {{Quote |The inhabitants, if they can be called that, move through their days in a trance-like manner, their actions governed by the city's oppressive rhythm rather than any discernible purpose. They drift through the shadowy streets, their forms often indistinguishable from the pervasive gloom that surrounds them. Their movements are slo..."
wikitext
text/x-wiki
{{stub}}
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}.
== Overview ==
{{Quote
|The inhabitants, if they can be called that, move through their days in a trance-like manner, their actions governed by the city's oppressive rhythm rather than any discernible purpose. They drift through the shadowy streets, their forms often indistinguishable from the pervasive gloom that surrounds them. Their movements are slow and deliberate, almost mechanical, as if each step is taken in reluctant compliance with an unseen force.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
1fac3c562d846adb7b3b2e5ab3eb4d386c14b532
Upgrade Module
0
425
612
2025-07-23T04:05:28Z
Sharparam
284703
Created page with "{{Infobox/Item | title = {{PAGENAME}} | image = Upgrade Module.png | Description = A rare artifact used in the process of upgrading gear. }} '''{{PAGENAME}}''' is an [[Upgrade items|upgrade item]] in {{BFF}}. It is used to upgrade equipment to Mk 4 and 5. {{Navbox/Items}} [[Category:Essential items]] [[Category:Upgrade items]]"
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Upgrade Module.png
| Description = A rare artifact used in the process of upgrading gear.
}}
'''{{PAGENAME}}''' is an [[Upgrade items|upgrade item]] in {{BFF}}. It is used to upgrade equipment to Mk 4 and 5.
{{Navbox/Items}}
[[Category:Essential items]]
[[Category:Upgrade items]]
f405ef0912d49ef39a269fb10d08d14c1e5322bb
Upgrade Splinter
0
432
626
2025-07-23T04:08:00Z
Sharparam
284703
wikitext
text/x-wiki
'''{{PAGENAME}}''' is an item found in {{BFF}} used to enhance [[weapons]] and [[armor]] to Mk 1, 2, and 3.
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found in the first big rectangular structure with pillars, near the [[Paladin Mace]]. Facing where the mace is, head right and past the red traffic light to find the item sitting on a ledge. || {{coords|-5173|-1105|5626}}
|}
{{Navbox/Items}}
[[Category:Upgrade items]]
b5014301a8a656873f94d981f8cd2ac3b7f1bbb7
Serpentine Visions
0
382
526
2025-07-23T04:47:01Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |Among the towering spires of the city, there are whispers of a colossal sky serpent that drifts silently through the steel and concrete canyons. Though the serpent is said to be harmless, its sheer size and graceful, serpentine movements evoke both awe and trepidation. With scales that shimmer in hues matching the city's metallic sheen, the serpent weaves effortle..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Among the towering spires of the city, there are whispers of a colossal sky serpent that drifts silently through the steel and concrete canyons. Though the serpent is said to be harmless, its sheer size and graceful, serpentine movements evoke both awe and trepidation. With scales that shimmer in hues matching the city's metallic sheen, the serpent weaves effortlessly through the narrow gaps between the tower, its long, undulating body casting an imposing shadow over the pristine surfaces below. its presence, though non-threatening, is a constant reminder of the vastness and wildness that still lingers even in this meticulously engineered urban landscape. The serpent's slow, deliberate light adds a touch of majesty and enigma to the stark cityscape, making its silent passage through the towering structures a mesmerizing spectacle that commands both reverence and respect.
}}
== Location ==
{{coords|9922|-6769|1440}}
Found in [[Uranopolis]] on a ledge on one of the platforms reached by navigating the bridges. Use [[Scanner|the scanner]] to find it more easily.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
e002a14503e5a3d60e77f6a2a8484fc1381a05d3
Amulet of Arcane Protection
0
516
795
2025-07-23T05:23:22Z
Sharparam
284703
Created page with "{{Infobox/Amulet | title = {{PAGENAME}} | image = Amulet of Arcane Protection.png | Passives = [[Techno-Defiance]] | Effect1 = +1500 [[Technomancy]] armor rating. }} '''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}. == Location == {{coords|4158|-2902|1459}} Found near the top side of a shortcut ladder in [[Uranopolis]]. {{Navbox/Amulets}}"
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Amulet of Arcane Protection.png
| Passives = [[Techno-Defiance]]
| Effect1 = +1500 [[Technomancy]] armor rating.
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Location ==
{{coords|4158|-2902|1459}}
Found near the top side of a shortcut ladder in [[Uranopolis]].
{{Navbox/Amulets}}
18efef3d358787360eb91c39568ddbe8822cdf47
Amulets
0
444
653
2025-07-23T05:24:10Z
Sharparam
284703
Created page with "{{Navbox/Amulets}}"
wikitext
text/x-wiki
{{Navbox/Amulets}}
c49a050c320d9cc83e8ac20203557bb1adb26913
Template:Navbox/Rings
10
292
371
370
2025-07-23T05:38:00Z
Sharparam
284703
Add [[Ring of Casting Speed]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
22577f5f9b1a9c7ae8bcc3b8f4ebca96fa12d371
372
371
2025-07-23T11:32:02Z
Sharparam
284703
Add [[Ring of Rammstein]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
* [[Ring of Rammstein]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
1ca9d6b8b77cbd2e141c78a56821fba79d958916
Ring of Casting Speed
0
520
803
2025-07-23T05:40:02Z
Sharparam
284703
Add note on acquisition
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Casting Speed.png
| Effect1 = -10% attack power.
| Effect2 = +20% technocasting speed.
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Acquisition ==
Drops from a giant enemy in [[Uranopolis]], around {{coords|-1151|-4475|1453}}.
{{Navbox/Rings}}
46f3eb13e5516b422e23a89fb5ec0e0a924ed783
Shifting Sands
0
383
528
2025-07-23T06:07:44Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |There are unsettling rumors about a colossal worm with wings made of bones, said to inhabit a hidden realm. This serpentine creature is described as having a face that resembles a person frozen in a dream, an eerie visage that defies understanding. The worm is said to speak and whisper to anyone who dares enter its domain—or even to those who merely think about..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|There are unsettling rumors about a colossal worm with wings made of bones, said to inhabit a hidden realm. This serpentine creature is described as having a face that resembles a person frozen in a dream, an eerie visage that defies understanding. The worm is said to speak and whisper to anyone who dares enter its domain—or even to those who merely think about it. Its nature alludes to something of maker origin. Something capable of changing the structure.
}}
== Location ==
{{coords|-9400|7378|-1350}}
Found in [[Desert|the Desert]], near the big enemy with red eyes after crossing the bridge past the [[Homunculus]]. It is in front of a set of doors.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
b48a873694f25c03f22938908578b61c6b9c4912
Call of the Void
0
384
530
2025-07-23T09:40:14Z
Sharparam
284703
Add missing location info
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|The giant staircase looms before me, its sheer expanse a vertiginous marvel that seems to stretch endlessly downward into the void. Each step is a monstrous slab of cold, unfeeling metal, worn smooth by countless unknown feet. As I descend, the sense of vertigo intensifies, and the emptiness below grows ever more profound. The abyss at the base of the staircase seems to call out with an irresistible allure, a dark, seductive whisper that tugs at the edges of my mind. The staircase feels alive with this haunting invitation, a siren song of emptiness that beckons irresistibly into the darkness below.
}}
== Location ==
{{coords|1132|-8482|1965}}
Found in [[Ghost Town#Floor 13|Ghost Town (Floor 13)]]. Starting from the [[Homunculus]], head down the stairs. Head up the stairs behind the crying enemy at the bottom and the data log will be at the end of the walkway. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
6926f68eafdb547e25880491f97dcb505ad73b95
Amulet of Evasion
0
517
797
2025-07-23T10:01:14Z
Sharparam
284703
Created page with "{{Infobox/Amulet | title = {{PAGENAME}} | image = Amulet of Evasion.png | Passives = [[Extended Evasion]] }} '''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}. == Location == {{coords|1251|-8419|551}} Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], go through the doorway and take the left path. When at the outdoors area, take the big stairs up and head immediately right, then to the wall and the item will be in a corner on the right..."
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Amulet of Evasion.png
| Passives = [[Extended Evasion]]
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Location ==
{{coords|1251|-8419|551}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], go through the doorway and take the left path. When at the outdoors area, take the big stairs up and head immediately right, then to the wall and the item will be in a corner on the right, behind a building.
{{Navbox/Amulets}}
9e21e16f6b5f152489ca325ce8295f57ce37b702
Umbral City
0
385
532
2025-07-23T10:20:41Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |I stumbled through the mist-shrouded sector of the city, disoriented and weary, an unsettling chill gripped me. The residential area ahead was cloaked in an eerie, ghastly haze. Every step felt heavier, as if the very air was laden with the weight of forgotten despair. I descended further into the sector, my path leading me to a graveyard that lay at the bottom, s..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|I stumbled through the mist-shrouded sector of the city, disoriented and weary, an unsettling chill gripped me. The residential area ahead was cloaked in an eerie, ghastly haze. Every step felt heavier, as if the very air was laden with the weight of forgotten despair. I descended further into the sector, my path leading me to a graveyard that lay at the bottom, shrouded in the same pervasive mist. The gravestones, ancient and crumbling, stood like mournful sentinels in the ghostly fog. I could feel a strange, unsettling energy emanating from the ground, a spectral force that seemed to pulse through the halls around me. The sorrow and loss from the graveyard seeped into the very walls of this place, wrapping me in a shroud of grief. The haunting resonance of the graveyard's energy made every breath feel heavy, and the oppressive atmosphere left me with an unshakable sense of inescapable sorrow, as if the very essence of this forsaken place was reaching out to ensnare me.
}}
== Location ==
{{coords|1109|-9166|-1494}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], go through the doorway and take the right path, going down the stairs and following the corridors until you arrive at the subway. Go to the right and get to the end to find the data log in the corner. Use [[Scanner|the scanner]] to more easily find it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
f48b4c78d4059ac73cd01b56ac5efdc5e95bd143
Intercepted Transmission
0
386
534
2025-07-23T10:27:43Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |You won't get to see the fruits of your sacrifice, and only you will ever know the pain of your solitude. I'm sorry. I'll never forget you. }} == Location == {{coords|1908|-1765|-806}} In [[Blok 6147]]. After exiting the [[subway]], take that path that leads up and then walk down the stairs to find the data log in a corner. Use [[Scanner|the scanner]] to find it..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|You won't get to see the fruits of your sacrifice, and only you will ever know the pain of your solitude. I'm sorry. I'll never forget you.
}}
== Location ==
{{coords|1908|-1765|-806}}
In [[Blok 6147]]. After exiting the [[subway]], take that path that leads up and then walk down the stairs to find the data log in a corner. Use [[Scanner|the scanner]] to find it more easily.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
f7a214fac38ad015fc367e76f78b3c313073255d
Spiked Shield
0
750
1160
2025-07-23T10:38:31Z
Sharparam
284703
Created page with "{{Infobox/Shield | title = {{PAGENAME}} | image = Spiked Shield.png | Weight = Heavy | Passives = [[Spikes]] | Mk0_Sharp = 48.6 | Mk0_Blunt = 54.6 | Mk0_Technomancy = 49.8 }} '''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}. == Acquisition == Dropped by [[Plagued Warden]]. {{Navbox/Shields}}"
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Spiked Shield.png
| Weight = Heavy
| Passives = [[Spikes]]
| Mk0_Sharp = 48.6
| Mk0_Blunt = 54.6
| Mk0_Technomancy = 49.8
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Acquisition ==
Dropped by [[Plagued Warden]].
{{Navbox/Shields}}
35d72a537a85e4efbf9cffb04c27d03f7ce129cf
Level
0
707
1080
2025-07-23T10:52:24Z
Sharparam
284703
Add more level data
wikitext
text/x-wiki
{{stub}}
'''{{PAGENAME}}''' is a measure of a player's experience.
== Overview ==
The level increases by gaining experience points through exploration, defeating [[enemies]], and picking up or interacting with [[items]] or [[lore]] objects.
The amount of experience points required to reach further levels will regularly increase, although not with every level.
Every level up also grants two attribute points that can be used to increase player [[attributes]]. When reaching level 25 you get 6 points instead of 2.
The max level is 25, with each [[NG+]] iteration increasing the cap by 5, to a maximum of 40 in [[NG+|NG+3]].
{| class="wikitable sticky-header hover-highlight" style="text-align: right;"
|-
! scope="col" | Level
! scope="col" | EXP to next
! scope="col" | Cost increase
! scope="col" | Total EXP
|-
| 0 || {{fnum|480}} || {{fnum|480}} || {{fnum|0}}
|-
| 1 || {{fnum|1220}} || {{fnum|740}} || {{fnum|480}}
|-
| 2 || {{fnum|2250}} || {{fnum|1030}} || {{fnum|1700}}
|-
| 3 || {{fnum|13500}} || {{fnum|11250}} || {{fnum|3950}}
|-
| 4 || {{fnum|13500}} || {{fnum|0}} || {{fnum|17450}}
|-
| 5 || {{fnum|15000}} || {{fnum|1500}} || {{fnum|30950}}
|-
| 6 || {{fnum|15000}} || {{fnum|0}} || {{fnum|45950}}
|-
| 7 || {{fnum|15000}} || {{fnum|0}} || {{fnum|60950}}
|-
| 8 || {{fnum|15000}} || {{fnum|0}} || {{fnum|75950}}
|-
| 9 || {{fnum|15000}} || {{fnum|0}} || {{fnum|90950}}
|-
| 10 || {{fnum|18500}} || {{fnum|3500}} || {{fnum|105950}}
|-
| 11 || {{fnum|18500}} || {{fnum|0}} || {{fnum|124450}}
|-
| 12 || {{fnum|18500}} || {{fnum|0}} || {{fnum|142950}}
|-
| 13 || {{fnum|18500}} || {{fnum|0}} || {{fnum|161450}}
|-
| 14 || {{fnum|18500}} || {{fnum|0}} || {{fnum|179950}}
|-
| 15 || {{fnum|21500}} || {{fnum|3000}} || {{fnum|198450}}
|-
| 16 || {{fnum|21500}} || {{fnum|0}} || {{fnum|219950}}
|-
| 17 || {{fnum|21500}} || {{fnum|0}} || {{fnum|241450}}
|-
| 18 || {{fnum|21500}} || {{fnum|0}} || {{fnum|262950}}
|-
| 19 || {{fnum|21500}} || {{fnum|0}} || {{fnum|284450}}
|-
| 20 || {{fnum|25000}} || {{fnum|3500}} || {{fnum|305950}}
|-
| 21 || {{fnum|25000}} || {{fnum|0}} || {{fnum|330950}}
|-
| 22 || {{fnum|25000}} || {{fnum|0}} || {{fnum|355950}}
|-
| 23 || {{fnum|25000}} || {{fnum|0}} || {{fnum|380950}}
|-
| 24 || {{fnum|25000}} || {{fnum|0}} || {{fnum|405950}}
|-
| 25 || ??? || ??? || {{fnum|430950}}
|}
[[Category:Game mechanics]]
2d60aff79f3c19820de1c03f6ed887e247b40df6
Techpriest Helmet
0
491
746
2025-07-23T11:12:30Z
Sharparam
284703
Created page with "{{Infobox/Armor | title = {{PAGENAME}} | image = Techpriest Helmet.png | Type = Helmet | Weight = Light | Passives = [[Minor Flux Regen]] | Mk5_Sharp = 722 | Mk5_Blunt = 722 | Mk5_Technomancy = 928 }} '''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}. == Location == {{coords|1272|-8495|551}} Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], head through the doorway and take the left path. After reaching the outdoors area, head up the s..."
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Techpriest Helmet.png
| Type = Helmet
| Weight = Light
| Passives = [[Minor Flux Regen]]
| Mk5_Sharp = 722
| Mk5_Blunt = 722
| Mk5_Technomancy = 928
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|1272|-8495|551}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], head through the doorway and take the left path. After reaching the outdoors area, head up the stairs and take a narrow path on the right leading to a small area behind a building with the helmet in a corner.
{{Navbox/Armor}}
a7a7b23c199012fb916ce23130908fb2796a023c
Tech Shield
0
752
1164
2025-07-23T11:29:29Z
Sharparam
284703
Created page with "{{Infobox/Shield | title = {{PAGENAME}} | image = Tech Shield.png | Weight = Heavy | Abilities = [[Refraction]] | Mk2_Sharp = 42.7 | Mk2_Blunt = 47.6 | Mk2_Technomancy = 70 }} '''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}. == Location == {{coords|1327|-9333|1892}} Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. After reaching the outdoors area, head up the stairs and..."
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Tech Shield.png
| Weight = Heavy
| Abilities = [[Refraction]]
| Mk2_Sharp = 42.7
| Mk2_Blunt = 47.6
| Mk2_Technomancy = 70
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Location ==
{{coords|1327|-9333|1892}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. After reaching the outdoors area, head up the stairs and take the left path. At the end is a cliff, climb it by standing near it and repeatedly tapping the jump button. Once on top of the cliff, go to the right and you'll see the corpse with the item against a cliff wall.
On the same corpse can also be found the [[Ring of Rammstein]].
{{Navbox/Shields}}
1e64b4aa14aac12ca5c32867c37f664acb36dedf
Ring of Rammstein
0
521
805
2025-07-23T11:31:46Z
Sharparam
284703
Created page with "{{Infobox/Ring | title = {{PAGENAME}} | image = Ring of Rammstein.png | Passives = [[Momentum Strike]] }} '''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}. == Location == {{main|Tech Shield#Location}} This item is located on the same corpse as the [[Tech Shield]]. {{Navbox/Rings}}"
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Rammstein.png
| Passives = [[Momentum Strike]]
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Location ==
{{main|Tech Shield#Location}}
This item is located on the same corpse as the [[Tech Shield]].
{{Navbox/Rings}}
1bf2ae52125b19a63277c4ea076e1cf3f2107e6e
Ability Splinter
0
430
622
2025-07-23T11:39:08Z
Sharparam
284703
Add another splinter in ghost town floor 1
wikitext
text/x-wiki
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}. It is used to equip and change [[abilities]].
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found near the [[Paladin Mace]]. Facing where the mace is, head left and slightly behind and look behind the large pillar to find the item. || {{coords|-4581|-7721|5575}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and keep right until you get to the room with a staircase going down. Before heading down the staircase, walk around it on its right and check the corner to find the item. || {{coords|1120|-7590|161}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and take the left path. In the outdoors area, head up the stairs and take the second right to get to the edge of the cliff with a bunch of graves. The item can be found near one of the graves. || {{coords|1321|-8034|190}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and take the left path. In the outdoors area, head up the stairs and take the left path to a cliff. Climb the cliff by repeatedly tapping the jump button. Once at the top, take the path leading down and follow it past a group of buildings (where the [[Soul Reaper]] can be found). Past the buildings are a set of graves with the item on top of one of them.
|}
{{Navbox/Items}}
[[Category:Essential items]]
7b6f4fe171581f79b13cd24ed99204aef452dab4
Deserts Respirator Helmet
0
492
748
2025-07-23T12:55:56Z
Sharparam
284703
Created page with "{{Infobox/Armor | title = {{PAGENAME}} | image = Deserts Respirator Helmet.png | Type = helmet | Weight = Medium | Mk2_Sharp = 545 | Mk2_Blunt = 633 | Mk2_Technomancy = 336 }} '''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}. == Location == {{coords|1367|6630|-1395}} Found in the [[Desert]]. Located on a corpse near the portal to [[Desert Mirage]]. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Deserts Respirator Helmet.png
| Type = helmet
| Weight = Medium
| Mk2_Sharp = 545
| Mk2_Blunt = 633
| Mk2_Technomancy = 336
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|1367|6630|-1395}}
Found in the [[Desert]]. Located on a corpse near the portal to [[Desert Mirage]].
{{Navbox/Armor}}
85a4c5a22cdde742f764acd2e76c15d11d03503d
Desert Dream
0
387
536
2025-07-23T13:07:11Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |According to the readings, this gateway offers a glimpse into a reality untouched by the distortions and chaos of [[The Anomaly|the anomaly]], a place where time and space unfolded in a different manner, free from the relentless upheaval that defines this place. The sand serpent's presence must be related. }} == Location == {{coords|1471|6344|-1395}} Found in th..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|According to the readings, this gateway offers a glimpse into a reality untouched by the distortions and chaos of [[The Anomaly|the anomaly]], a place where time and space unfolded in a different manner, free from the relentless upheaval that defines this place. The sand serpent's presence must be related.
}}
== Location ==
{{coords|1471|6344|-1395}}
Found in the [[Desert]]. It's located in front of the teleportation orb that leads to [[Desert Mirage]].
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
fb7777879af3c3d248160f4349e8cabe96b0e304
Template:Navbox/Rings
10
292
373
372
2025-07-23T14:04:35Z
Sharparam
284703
Add [[Ring of Exceeding Talent]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
* [[Ring of Exceeding Talent]]
* [[Ring of Rammstein]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
41ad293567046b38a2ccf209a3fa705c5e4a8431
374
373
2025-07-23T14:07:38Z
Sharparam
284703
Add more rings
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
* [[Ring of Rammstein]]
* [[Ring of Lesser Talent]]
* [[Ring of Talent]]
* [[Ring of Exceeding Talent]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
370f3235addc2ae182daa771a1fe2c1179b6433f
Ring of Exceeding Talent
0
522
807
2025-07-23T14:07:05Z
Sharparam
284703
Add notes on other ring versions
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Exceeding Talent.png
| Effect1 = +3 [[Strength]]
| Effect2 = +3 [[Agility]]
| Effect3 = +3 [[Constitution]]
| Effect4 = +3 [[Intelligence]]
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Location ==
{{coords|3720|1159|-1397}}
Located in the [[Desert]] on a toppled pillar in the area with Yaroslav's crew (same location as the [[Handler Echo]]).
== See also ==
* [[Ring of Lesser Talent]] – The weakest version of this ring.
* [[Ring of Talent]] – A weaker version of this ring.
{{Navbox/Rings}}
bcbe61aaf34441d0c94fadf4e2d02dbe42c66205
Saracen Shield
0
749
1158
2025-07-23T14:10:02Z
Sharparam
284703
Created page with "{{Infobox/Shield | title = {{PAGENAME}} | image = Saracen Shield.png | Weight = Heavy | Abilities = [[Regal Radiance]] | Mk2_Sharp = 59.5 | Mk2_Blunt = 57.4 | Mk2_Technomancy = 69.3 }} '''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}. == Location == {{cords|3760|1142|-1395}} Found in the [[Desert]]. In the area with Yaroslav's crew, look behind the big statue head to find the shield. {{Navbox/Shields}}"
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Saracen Shield.png
| Weight = Heavy
| Abilities = [[Regal Radiance]]
| Mk2_Sharp = 59.5
| Mk2_Blunt = 57.4
| Mk2_Technomancy = 69.3
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Location ==
{{cords|3760|1142|-1395}}
Found in the [[Desert]]. In the area with Yaroslav's crew, look behind the big statue head to find the shield.
{{Navbox/Shields}}
59fda45f4bdf41eba1f4a2bcf8c2764d16851685
Template:Navbox/Shields
10
440
640
2025-07-23T14:10:17Z
Sharparam
284703
Add [[Saracen Shield]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Shields
| title = [[Shields]]
| list1 =
* [[Flat Shield]]
* [[Kite Shield]]
* [[Military Shield]]
* [[Saracen Shield]]
* [[Spiked Shield]]
* [[Tall Military Shield]]
* [[Tech Shield]]
* [[Wooden Shield]]
}}
86b51292309060d7ff355bad7dc03a02f84ab69b
Wormlord
0
547
854
2025-07-23T15:10:54Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Wormlord.png
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Overview ==
Defeating Wormlord is required to be able to access [[The Anomaly]].
== Location ==
{{coords|2550|-4122|-1198}} (approximate)
Found in [[Desert Mirage]]. The entire area is dedicated as its boss arena.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
aedb9551379ee1f1febb972b361a1b8ee9e1c3fd
Plagued Revenant
0
546
852
2025-07-23T15:49:07Z
Sharparam
284703
Add drops
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Plagued Revenant.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|1432|-8866|199}} (approximate)
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. After getting to the outdoors area, keep going straight until you get to the end, take a right and then left to get down to a cliff area. Go left and you'll see a mausoleum inside the cliff on the left with some graves in front of it. In front of the doors of this mausoleum is a helmet ({{coords|1409|-8884|190}}). Interacting with the helmet to attempt to take it will spawn the boss behind you.
== Drops ==
* [[Anastasia]]
* [[Plagued Revenant Helmet]]
== Trivia ==
* When dying to this boss, crying can be heard during the loading screen. This could either be intentional or a result of the nearby crying enemy respawning.
{{Navbox/Bosses}}
698530510328c2e5031366f6586a3eb9494a65e4
Plagued Revenant Helmet
0
493
750
2025-07-23T15:54:24Z
Sharparam
284703
Created page with "{{Infobox/Armor | title = {{PAGENAME}} | image = Plagued Revenant Helmet.png | Type = Helmet | Weight = Medium | Mk5_Sharp = 883 | Mk5_Blunt = 1024 | Mk5_Technomancy = 540 }} '''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}. == Acquisition == Drops from [[Plagued Revenant]]. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Plagued Revenant Helmet.png
| Type = Helmet
| Weight = Medium
| Mk5_Sharp = 883
| Mk5_Blunt = 1024
| Mk5_Technomancy = 540
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Acquisition ==
Drops from [[Plagued Revenant]].
{{Navbox/Armor}}
dcf20306f52ebb49a60617476143ab6a73580f6b
Template:Navbox/Data logs
10
290
358
357
2025-07-23T16:10:07Z
Sharparam
284703
Add [[Heartbeat]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
3c6a050fdfdb7b63e99e373283ffefe800945ed9
359
358
2025-07-23T21:55:30Z
Sharparam
284703
Add [[Silent Streets]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Manta Rays]]
* [[The Structure]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
d07fb4d47edebed387a1692c9bb48a34db0f5a42
360
359
2025-07-23T22:03:53Z
Sharparam
284703
Add [[Statues]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[The Structure]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
4958d07a84a6bc62127f9a55e125eac5fdc500dd
361
360
2025-07-23T23:25:11Z
Sharparam
284703
Add more data logs
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[The Structure]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
a51dfbf017a3f2bb41892278e10183b069414667
Heartbeat
0
388
538
2025-07-23T16:14:07Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |Have you ever tried to paint a loved one's face from memory? The image shifts and deforms, highlighting the mind's fleeting nature. Drawing from memory is an abstract skill, breathing and heartbeats are automatic. Now, even these feel abstract to me. I have to consciously breathe and encourage my heart to beat, doubting its rhythm if I can't feel it. My heartbeat..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Have you ever tried to paint a loved one's face from memory? The image shifts and deforms, highlighting the mind's fleeting nature. Drawing from memory is an abstract skill, breathing and heartbeats are automatic. Now, even these feel abstract to me. I have to consciously breathe and encourage my heart to beat, doubting its rhythm if I can't feel it. My heartbeat feels like as word repeated until it loses meaning. Nothing endures here.
}}
== Location ==
{{coords|3326|-6471|-6573}}
Found in the [[Monastery#Lower|Monastery (Lower)]]. Starting at the [[Homunculus]], go forward until the end of the roof where the first enemy is, then take the left path that goes down several stairs. Continue into the hallway at the bottom and take a left, then go up the elevator. Go straight and you'll come to a platform with a staircase going up to the right. The data log is right before the staircase. Use [[Scanner|the scanner]] to more easily find it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data log]]
e6a4f885a6f4e9bd91ce07da3168957b45e7a308
Perk Essence
0
424
610
2025-07-23T16:34:38Z
Sharparam
284703
wikitext
text/x-wiki
{{Infobox/Item
| tabs = Stable,Unstable
| images = [[File:Perk Essence.png|300px]],[[File:Unstable Perk Essence.png|300px]]
| Stable_title = Perk Essence
| Unstable_title = Unstable Perk Essence
| Stable_Description = An artifact used in the process of embedding perks.
| Unstable_Description = Get to a checkpoint to turn it into a perk, on death goes back to it's [sic] original location.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] used to acquire [[perks]] or perk upgrades.
== Acquisition ==
The unstable variant drops from some [[bosses]] (excluding mini-bosses), bringing it to a [[homunculus]] without dying stabilises it. It has to be brought to a normal homunculus, not one spawned by the [[Homunculus Mirage]].
Dying on the way to a homunculus while the item is still in its unstable form will respawn it in the boss's arena, forcing the player to go back and pick it up again.
{{Navbox/Items}}
[[Category:Essential items]]
e1971e413ec50fbb2dc150383cacbe574eece1c5
Librarian Hood
0
494
752
2025-07-23T16:42:03Z
Sharparam
284703
Created page with "{{Infobox/Armor | title = {{PAGENAME}} | image = Librarian Hood.png | Type = Helmet | Weight = Light | Set = Librarian | Mk1_Sharp = 371 | Mk1_Blunt = 371 | Mk1_Technomancy = 469 }} '''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}. == Acquisition == Drops from [[Librarian (enemy)|librarian]] enemies. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Librarian Hood.png
| Type = Helmet
| Weight = Light
| Set = Librarian
| Mk1_Sharp = 371
| Mk1_Blunt = 371
| Mk1_Technomancy = 469
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Acquisition ==
Drops from [[Librarian (enemy)|librarian]] enemies.
{{Navbox/Armor}}
524d688d52e40e59b69ca9f6a46e4f593a6fcdab
Librarian (armor set)
0
487
738
2025-07-23T16:43:16Z
Sharparam
284703
Fix names
wikitext
text/x-wiki
{{Infobox/Armor set
| image = Librarian.png
| title = Librarian
| Weight = Light
| Helmet = Librarian Hood
| Pauldrons = <!-- Librarian ??? -->
| Chestguard = Librarian Overcoat
| Legguard = Librarian Trousers
| Gauntlets = <!-- Librarian ??? -->
}}
'''Librarian''' is an [[armor set]] in {{BFF}}.
== Pieces ==
* [[Librarian Hood]]
<!-- * [[Librarian ???]] -->
* [[Librarian Overcoat]]
* [[Librarian Trousers]]
<!-- * [[Librarian ???]] -->
{{Navbox/Armor}}
ad355bf6137087d645f4fbb2ac96e384f57db8a8
Librarian
0
745
1150
2025-07-23T16:51:24Z
Sharparam
284703
Created page with "'''Librarian''' may refer to: == Common meanings == * [[Librarian (armor set)]], a light armor set * [[Librarian (enemy)]], the enemy in the [[Monastery]] == See also == * [[Librarian Hood]] * [[Librarian Overcoat]] * [[Librarian Trousers]] {{Disambiguation}}"
wikitext
text/x-wiki
'''Librarian''' may refer to:
== Common meanings ==
* [[Librarian (armor set)]], a light armor set
* [[Librarian (enemy)]], the enemy in the [[Monastery]]
== See also ==
* [[Librarian Hood]]
* [[Librarian Overcoat]]
* [[Librarian Trousers]]
{{Disambiguation}}
c7eb5b123cb7063d1af9038ba92b3013df3b5b50
Katanas
0
475
714
2025-07-23T21:02:24Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Katanas.png
| Type = Dual Wield
| Speed = Fast
| Damage type = Sharp
| Abilities = Blade Dash, Whirlwind Strike
| Mk3_Damage_min = 117
| Mk3_Damage_max = 130
| Mk4_Damage_min = 165
| Mk4_Damage_max = 183
| Mk5_Damage_min = 235
| Mk5_Damage_max = 261
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
Available as a drop from [[enemies]] in [[Uranopolis#Tower Complex|Uranopolis (Tower Complex)]].
{{Navbox/Weapons}}
4ab46d81614502ef87bbdcd436c9621993e809bd
Anastasia
0
501
766
2025-07-23T21:03:19Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Anastasia.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Reanimate Dead, Silencing Reap
| Mk3_Damage_min = 364
| Mk3_Damage_max = 408
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Acquisition ==
Drops from [[Plagued Revenant]].
{{Navbox/Weapons}}
999c96e5d8b0e959b4174e16951f4d2f08e6598c
Arcane Bow
0
509
782
2025-07-23T21:11:05Z
Sharparam
284703
Fix template call (via JWB)
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Arcane Bow.png
| Type = Ranged
| Damage type = Sharp
| Speed = Fast
| Passives = Vermillion Judgment
| Abilities = Arrow Twister
| Mk2_Damage_min = 184
| Mk2_Damage_max = 197
| Mk3_Damage_min = 251
| Mk3_Damage_max = 267
| Mk4_Damage_min = 292
| Mk4_Damage_max = 312
| Mk5_Damage_min = 334
| Mk5_Damage_max = 356
}}
'''{{PAGENAME}}''' is a [[Bows|bow]] in {{BFF}}.
== Location ==
{{coords|1261|-8400|1563}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the left path. When in the outdoors area, head into the path on the right before the big stairs. Take the ladder at the end getting up onto a building, and then the next one. The item will be in the corner of the roof on a corpse.
{{Navbox/Weapons}}
9ed7d6da9990d1b86ae941adf6cc8ea5f6b173fb
Blades of Atropos
0
480
724
2025-07-23T21:11:13Z
Sharparam
284703
Fix template call (via JWB)
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Blades of Atropos.png
| Type = Dual Wield
| Damage type = Sharp
| Speed = Fast
| Passives = Bloodthirst
| Abilities = Phase
| Mk0_Damage_min = 131
| Mk0_Damage_max = 145
| Mk1_Damage_min = 147
| Mk1_Damage_max = 164
| Mk2_Damage_min = 164
| Mk2_Damage_max = 182
| Mk3_Damage_min = 197
| Mk3_Damage_max = 218
| Mk4_Damage_min = 229
| Mk4_Damage_max = 255
| Mk5_Damage_min = 262
| Mk5_Damage_max = 291
}}
'''{{PAGENAME}}''' are a [[Dual Wields|dual wield]] weapon in {{BFF}}.
== Location ==
{{coords|2778|-6115|-1198}}
Found in [[Desert Mirage]]. Just down the stairs from the [[Homunculus]].
{{Navbox/Weapons}}
52da0a005c0bcb26cb17a6ee2da89b32c687e4ea
Paladin Mace
0
497
758
2025-07-23T21:11:38Z
Sharparam
284703
Fix template call (via JWB)
wikitext
text/x-wiki
{{Infobox/Weapon
| image = Paladin Mace.png
| title = {{PAGENAME}}
| Type = one-handed
| Damage type = Blunt
| Speed = Fast
| Abilities = Divine Blessing
| Mk0_Damage_min = 76
| Mk0_Damage_max = 83
| Mk1_Damage_min = 85
| Mk1_Damage_max = 93
| Mk2_Damage_min = 95
| Mk2_Damage_max = 104
}}
'''{{PAGENAME}}''' is a [[One-handed weapons|one-handed]] [[Weapons|weapon]] that can be found in {{BFF}}.
== Location ==
{{coords|-4879|-7530|5578}}
In [[Deluge|the Deluge]]. Located in a square hole in the wall inside the first rectangular structure with pillars after crossing a bridge. The [[Items|item]] can be seen straight ahead when crossing the bridge.
{{Navbox/Weapons}}
9ae9ef12f0012f7ee76e8b19eb462a731a31721f
Scimitar
0
498
760
2025-07-23T21:11:43Z
Sharparam
284703
Fix template call (via JWB)
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Scimitar.png
| Type = One-handed
| Damage type = Sharp
| Speed = Swift
| Abilities = Whiplash
| Mk2_Damage_min = 150
| Mk2_Damage_max = 163
}}
'''{{PAGENAME}}''' is a [[One-handed weapons|one-handed weapon]] in {{BFF}}.
== Location ==
{{coords|1713|7517|-1413}}
Located inside a building in the [[Desert]], after getting down on the bottom.
{{Navbox/Weapons}}
7da5444707df0750219ed6dda415a75ee3b04a8e
Asklepios
0
506
776
2025-07-23T21:13:46Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Asklepios.png
| Type = Staff
| Damage type = Technomancy
| Speed = Slow
| Abilities = Mending Light, Second Breath
| Mk3_Damage_min = 117
| Mk3_Damage_max = 120
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] weapon in {{BFF}}.
== Acquisition ==
Dropped by big floating knights with blue lightsabers in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]].
{{Navbox/Weapons}}
19d3bc07174d18e309f111ea29df123b354aac8e
Crescent Axe
0
502
768
2025-07-23T21:14:14Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Crescent Axe.png
| Type = two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Expose Armor, Crescent Slash
| Mk2_Damage_min = 251
| Mk2_Damage_max = 271
}}
== Location ==
{{coords|-3932|1535|1532}}
Located in the room with [[The Banshee]] [[Data logs|data log]].
6ae8e711635fe9f28bf31f5f61c2b8a34e8e0452
Khopeshs
0
479
722
2025-07-23T21:14:57Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Khopeshs.png
| Type = Dual Wield
| Damage type = Sharp
| Speed = Fast
| Abilities = Dual Brutality, Bladestorm
| Mk0_Damage_min = 92
| Mk0_Damage_max = 102
| Mk1_Damage_min = 104
| Mk1_Damage_max = 115
| Mk2_Damage_min = 115
| Mk2_Damage_max = 128
| Mk3_Damage_min = 139
| Mk3_Damage_max = 154
}}
'''{{PAGENAME}}''' are a type of [[Dual Wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
Dropped by [[Plagued Nemesis]].
{{Navbox/Weapons}}
c8f5f702bd2d22af0adff4ad34825ffb25021210
Lacerators
0
477
718
2025-07-23T21:15:17Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Lacerators.png
| Type = Dual Wield
| Speed = Fast
| Damage type = Sharp
| Passives = Lacerate, Lifesteal
| Mk2_Damage_min = 97
| Mk2_Damage_max = 108
| Mk5_Damage_min = 235
| Mk5_Damage_max = 261
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
{{Navbox/Weapons}}
b1946670af3fe4f2bd09c0dfc86872b327a200a9
Nodachi
0
499
762
2025-07-23T21:15:34Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Nodachi.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Whirlwind, Tornado
| Mk3_Damage_min = 315
| Mk3_Damage_max = 344
| Mk4_Damage_min = 368
| Mk4_Damage_max = 402
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Acquisition ==
Dropped by [[Nurgei the Blademaster]].
{{Navbox/Weapons}}
86417f91f727b87f778da76948fb454da2e92744
Royal Claymore
0
503
770
2025-07-23T21:15:53Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Royal Claymore.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Claymore Swing, Sword Strike
| Mk3_Damage_min = 315
| Mk3_Damage_max = 344
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Location ==
{{coords|-9938|7939|-1340}}
Found in [[Desert|the Desert]]. Starting where the [[Shifting Sands]] data log can be found, climb up the stairs on either side and walk through the arch. The item can be seen across a gap. Do a jump while sprinting to cross the gap and reach the item.
{{Navbox/Weapons}}
d8f571fe32e600c12e02d6d3d5e06dac9e5df229
Soul Reaper
0
500
764
2025-07-23T21:16:16Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Soul Reaper.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Reap, Soul Storm
| Mk3_Damage_min = 322
| Mk3_Damage_max = 361
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Location ==
{{coords|1413|-9293|190}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. When reaching the outdoors area, head up the stairs and go left. Climb up the cliff by repeatedly tapping the jump button. Once at the top, head forward and follow the path that leads downwards. Eventually you will reach a group of buildings. In front of one of these is the weapon.
{{Navbox/Weapons}}
950b71e0fc9d4dbdefdb52a2c58ee43849dd7600
Twinblade
0
505
774
2025-07-23T21:16:32Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Twinblade.png
| Type = Twinblade
| Damage type = Sharp
| Speed = Swift
| Abilities = Blade Dance, Blade Flurry
| Mk3_Damage_min = 75
| Mk3_Damage_max = 78
}}
'''{{PAGENAME}}''' is a [[Twinblades|twinblade]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
Drops from [[enemies]] using the twinblade weapon.
{{Navbox/Weapons}}
f75786b2c8e5d234ef871b2f5c2e32b4924b1b6a
Greater Anomalous Crystal
0
420
602
2025-07-23T21:45:55Z
Sharparam
284703
Add Blok 6147 location and improve table
wikitext
text/x-wiki
'''{{PAGENAME}}''' is an [[Items|item]] found in {{BFF}}. It can be embedded into [[weapons]] or [[armor]] to improve their properties.
== Variants ==
There are several different variants of the crystal that all share the same name in-game, differing only by their visual appearance and the effects they give when embedded into [[equipment]].
They have received ad-hoc names on the wiki temporarily to be able to differentiate them. The names are assigned based on the item's appearance.
=== "Purple jagged" ===
* '''Effect in [[armor]]:''' +25 max [[flux]] points.
* '''Effect in [[weapons]]:''' +8% [[technomancy]] penetration.
=== "Orange shield" ===
* '''Effect in [[armor]]:''' +30% base weapon damage.
* '''Effect in [[weapons]]:''' +9% attack power.
=== "Ruby" ===
* '''Effect in [[armor]]:''' +75 max health points.
* '''Effect in [[weapons]]:''' +15% critical damage.
== Locations ==
{| class="wikitable sortable"
! scope="col" | Area
! scope="col" class="unsortable" | Description
! scope="col" class="unsortable" | Coordinates
! scope="col" | Variant
|-
| [[Blok 6147]] || For now, refer to a walkthrough video on Discord.[https://discord.com/channels/541778372997677056/1087019327712133140/1087020918221590608] || {{coords|-1155|-1340|2635}} || Orange shield
|-
| [[Deluge]] || Starting from the first [[homunculus]] in the area, climb the stairs (past [[The Handler]]) and enter the small tower inhabited by a [[Diver]] [[Enemies|enemy]]. Look over the edge and you'll see a rusty walkway circling the tower. Drop down onto the walkway and follow it to the right (the direction the enemy was facing) and keep following it to find a ladder going up. Climb the ladder and continue straight to notice a gap in the floor, jump the gap and continue forward to find the crystal. (Going down the gap leads to a post-process effect unlock ("Dramatic").) || {{coords|-3178|-1346|5700}} || Purple jagged
|-
| [[Uranopolis]] || Next to a tree near the giant enemy that drops [[Ring of Casting Speed]]. || {{coords|-2185|-4082|1473}} || Orange shield
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting at the [[Homunculus]], head through the doorway and take the left path. When in the outdoors area, head up the big stairs and take the left path. At the end is a big cliff. Walk near the cliff and use the jump button repeatedly to climb to the top of the cliff. The item is on the edge of the cliff. || {{coords|1246|-8872|1517}} || Ruby
|}
{{Navbox/Items}}
[[Category:Items]]
[[Category:Anomalous crystals]]
f3dbb5471d067f2759e3b9ef743f9c6ebc7f3619
Silent Streets
0
389
540
2025-07-23T22:01:44Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |Interaction between the city's inhabitants is minimal and strangely formal. They pass one another with vacant, almost resigned nods, their conversations reduced to whispers that blend seamlessly with the ambient hum of the city. The air is filled with a sense of inevitability, as if their routines are an attempt to impose a semblance of order on an environment tha..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Interaction between the city's inhabitants is minimal and strangely formal. They pass one another with vacant, almost resigned nods, their conversations reduced to whispers that blend seamlessly with the ambient hum of the city. The air is filled with a sense of inevitability, as if their routines are an attempt to impose a semblance of order on an environment that has long forsaken any true sense of purpose or coherence. In this dreamlike, consuming city, their lives are a reflection of the city's own tragic state—a relentless cycle of existence without progress, forever trapped in the shadow of their own lost potential.
}}
== Location ==
{{coords|1244|1057|1956}}
Found in [[Blok 6147]]. In an alley with a fire and nearby cargo box. It's in the area with multiple walkways at different heights with stairs between.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
d244a7077b0a0b4ba8290bdd23f999bdbf664d08
Statues
0
390
542
2025-07-23T22:13:13Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |Often found in the narrow corridors and shadowy alcoves of the city, their bodies rigidly aligned as if caught in a perpetual moment of exhaustion. Some are positioned near the vast concrete walls, their outlines faintly illuminated by the dim, ambient light, creating haunting silhouettes against the cold surface. Their eyes vacant, reflecting the dim glow of the..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Often found in the narrow corridors and shadowy alcoves of the city, their bodies rigidly aligned as if caught in a perpetual moment of exhaustion. Some are positioned near the vast concrete walls, their outlines faintly illuminated by the dim, ambient light, creating haunting silhouettes against the cold surface. Their eyes vacant, reflecting the dim glow of the city in a fixed, lifeless gaze.
}}
== Location ==
{{coords|1424|1365|3124}}
Located in [[Blok 6147]] at the end of one of the walkways with stairs between them.
[[File:Statues_location.jpg|thumb|left|Location of the data log.|alt=Screenshot showing the location of the data log.]]
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
afc40155102345cb921361ea566916b295ded7c5
Eris
0
495
754
2025-07-23T22:31:35Z
Sharparam
284703
Created page with "{{Infobox/Armor | title = {{PAGENAME}} | image = Eris.png | Type = Helmet | Weight = Light | Passives = Flux Efficiency | Mk5_Sharp = 730 | Mk5_Blunt = 730 | Mk5_Technomancy = 939 }} '''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}. == Location == {{coords|2860|-4261|1423}} Found in [[Uranopolis#Tower Complex|Uranopolis (Tower Complex)]]. Nestled between some round pillars. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Eris.png
| Type = Helmet
| Weight = Light
| Passives = Flux Efficiency
| Mk5_Sharp = 730
| Mk5_Blunt = 730
| Mk5_Technomancy = 939
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|2860|-4261|1423}}
Found in [[Uranopolis#Tower Complex|Uranopolis (Tower Complex)]]. Nestled between some round pillars.
{{Navbox/Armor}}
3716b6c0ca03c71f6dc10ebb3357cb49aa6862ef
Template:Infobox/Armor
10
453
670
2025-07-23T22:34:12Z
Sharparam
284703
Add support for passives
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Weight,Set,Passives
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| helmet = [[Helmet]]
| pauldrons = [[Pauldrons]]
| chestguard = [[Chestguard]]
| legguard = [[Legguard]]
| gauntlet = [[Gauntlet]]
| #default = {{{Type}}}
}}}}
|Set={{#if:{{{Set|}}}|[[{{{Set}}}]]}}
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \!
| token = @@@@
| pattern = [[@@@@]]
| intro = \{\{hlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| helmet = [[Category:Helmets]]
| pauldrons = [[Category:Pauldrons]]
| chestguard = [[Category:Chestguards]]
| legguard = [[Category:Legguards]]
| gauntlet = [[Category:Gauntlets]]
| #default = [[Category:Armor]]
}}{{Armor/CargoStore
|name={{{title|}}}
|setname={{{Set|}}}
|type={{{Type|}}}
|weight={{{Weight|}}}
|sharpMk0={{{Mk0_Sharp|}}}
|bluntMk0={{{Mk0_Blunt|}}}
|technomancyMk0={{{Mk0_Technomancy|}}}
|sharpMk1={{{Mk1_Sharp|}}}
|bluntMk1={{{Mk1_Blunt|}}}
|technomancyMk1={{{Mk1_Technomancy|}}}
|sharpMk2={{{Mk2_Sharp|}}}
|bluntMk2={{{Mk2_Blunt|}}}
|technomancyMk2={{{Mk2_Technomancy|}}}
|sharpMk3={{{Mk3_Sharp|}}}
|bluntMk3={{{Mk3_Blunt|}}}
|technomancyMk3={{{Mk3_Technomancy|}}}
|sharpMk4={{{Mk4_Sharp|}}}
|bluntMk4={{{Mk4_Blunt|}}}
|technomancyMk4={{{Mk4_Technomancy|}}}
|sharpMk5={{{Mk5_Sharp|}}}
|bluntMk5={{{Mk5_Blunt|}}}
|technomancyMk5={{{Mk5_Technomancy|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
b1b6719714f0e3277010b8ca8d5ecb76f9538378
Template:Infobox/Armor/doc
10
454
672
2025-07-23T22:35:47Z
Sharparam
284703
Update template data
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for armor",
"params": {
"image": {
"label": "Armor image",
"description": "Name of the file used as the image for the armor, should be at least 300 pixels wide.",
"required": true,
"example": "Cool armor.png",
"type": "wiki-file-name"
},
"Type": {
"label": "Armor type",
"description": "The type of armor.",
"required": true,
"example": "Helmet",
"type": "wiki-page-name"
},
"Weight": {
"label": "Armor weight",
"description": "The weight class of the armor.",
"required": true,
"example": "Light",
"type": "string"
},
"Set": {
"label": "Armor set",
"description": "Name of an armor set, if the piece is part of one.",
"required": false,
"example": "Cool set",
"type": "wiki-page-name"
},
"Passives": {
"label": "Passive effects",
"description": "Comma-separated list of passive effects",
"required": false,
"example": "Regen HP, Regen FX",
"type": "string"
},
"Mk1_Sharp": {
"label": "Mk 1 sharp rating",
"description": "Sharp defense rating at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Blunt": {
"label": "Mk 1 blunt rating",
"description": "Blunt defense rating at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Technomancy": {
"label": "Mk 1 technomancy rating",
"description": "Technomancy defense rating at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Sharp": {
"label": "Mk 2 sharp rating",
"description": "Sharp defense rating at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Blunt": {
"label": "Mk 2 blunt rating",
"description": "Blunt defense rating at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Technomancy": {
"label": "Mk 2 technomancy rating",
"description": "Technomancy defense rating at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Sharp": {
"label": "Mk 3 sharp rating",
"description": "Sharp defense rating at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Blunt": {
"label": "Mk 3 blunt rating",
"description": "Blunt defense rating at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Technomancy": {
"label": "Mk 3 technomancy rating",
"description": "Technomancy defense rating at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Sharp": {
"label": "Mk 4 sharp rating",
"description": "Sharp defense rating at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Blunt": {
"label": "Mk 4 blunt rating",
"description": "Blunt defense rating at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Technomancy": {
"label": "Mk 4 technomancy rating",
"description": "Technomancy defense rating at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Sharp": {
"label": "Mk 5 sharp rating",
"description": "Sharp defense rating at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Blunt": {
"label": "Mk 5 blunt rating",
"description": "Blunt defense rating at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Technomancy": {
"label": "Mk 5 technomancy rating",
"description": "Technomancy defense rating at Mk 5",
"required": true,
"example": "5",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Armor
| image = Helmet 2-1 SVG.svg
| title = Awesome helmet
| Type = Helmet
| Weight = Heavy
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Armor
| image = Helmet 2-1 SVG.svg
| title = Awesome helmet
| Type = Helmet
| Weight = Heavy
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
</syntaxhighlight>
03d97e9c6ffe6abdc853a4e886a5526e3ca4922d
Taskmaster
0
510
784
2025-07-23T23:20:45Z
Sharparam
284703
Created page with "{{Infobox/Weapon | title = {{PAGENAME}} | image = Taskmaster.png | Type = Ranged | Damage type = Sharp | Speed = Fast | Passives = Rapid Fire, Critical Strike | Mk2_Damage_min = 240 | Mk2_Damage_max = 256 }} '''{{PAGENAME}}''' is a [[Ranged weapons|ranged weapon]] in {{BFF}}. == Location == {{coord|4052|1265|-1412}} Located in the [[Desert]]. After meeting [[Yaroslav|Yaroslav's]] crew and passing through the passage to the big open area, look slightly to the left and..."
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Taskmaster.png
| Type = Ranged
| Damage type = Sharp
| Speed = Fast
| Passives = Rapid Fire, Critical Strike
| Mk2_Damage_min = 240
| Mk2_Damage_max = 256
}}
'''{{PAGENAME}}''' is a [[Ranged weapons|ranged weapon]] in {{BFF}}.
== Location ==
{{coord|4052|1265|-1412}}
Located in the [[Desert]]. After meeting [[Yaroslav|Yaroslav's]] crew and passing through the passage to the big open area, look slightly to the left and you'll see the bow resting against some run down brick arches.
{{Navbox/Weapons}}
dd37cc2a86e75e6fa9d8f0c27f5bfcb3c3a09e92
Unknown Limits
0
391
544
2025-07-23T23:28:39Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |From within, the boundary of the anomaly seems both infinite and elusive, with no clear beginning or end. It sprawls outwards in a chaotic, unpredictable manner, its influence warping space and time to create a disorienting and treacherous landscape. The sphere's growth is not linear but irregular, expanding and contracting as it incorporates elements from its sur..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|From within, the boundary of the anomaly seems both infinite and elusive, with no clear beginning or end. It sprawls outwards in a chaotic, unpredictable manner, its influence warping space and time to create a disorienting and treacherous landscape. The sphere's growth is not linear but irregular, expanding and contracting as it incorporates elements from its surroundings, twisting them into bizarre, unrecognizable forms.
}}
== Location ==
{{coords|4984|1575|-1420}}
Found in the [[Anomaly]]. When entering the area, it is the first thing you will come across as the cave opens up to the outdoors area. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
9c79704fa399a5c94c900c27d6cb8c39b760f58a
Template:Navbox/Items
10
285
322
321
2025-07-23T23:32:16Z
Sharparam
284703
Add link to essential items
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Essential items|Essential]]
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group1.1 = [[Upgrade items|Upgrade]]
| list1.1 =
* [[Upgrade Splinter]]
* [[Upgrade Module]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
7ddddd74185f43622c0032fb924e9ea4df3f2c1d
Template:Navbox/Locations
10
293
377
2025-07-24T16:38:41Z
Sharparam
284703
Created page with "<!-- The locations are ordered in the way they are listed in-game in the relocation menu --> {{Navbox | template = Navbox/Locations | title = [[Locations]] | list1 = * [[Monastery]] * [[Blok 6147]] * [[Rain District]] * [[Deluge]] * [[Asylum]] * [[Upper Blocks]] * [[Uranopolis]] * [[Ghost Town]] * [[Machinarium]] * [[Desert]] * [[Desert Mirage]] * [[Anomaly]] }}<noinclude> {{Documentation}} [[Category:Navigation templates]] </noinclude>"
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]]
* [[Blok 6147]]
* [[Rain District]]
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]]
* [[Ghost Town]]
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
a9919f8122c30db35e45bc7830af1bd611295ec1
378
377
2025-07-24T17:10:37Z
Sharparam
284703
Add links to sub-locations
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]] ([[Monastery#Lower|Lower]] · [[Monastery#Upper|Upper]])
* [[Blok 6147]]
* [[Rain District]] ([[Rain District#Sewers|Sewers]] · [[Rain District#Center|Center]])
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]] ([[Uranopolis#Tower Complex|Tower Complex]] · [[Uranopolis#Lone Tower|Lone Tower]])
* [[Ghost Town]] ([[Ghost Town#Floor 13|Floor 13]] · [[Ghost Town#Floor 1|Floor 1]])
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
91e37bd11620abbf81329f4ac0f61b9337538af4
Monastery
0
354
470
2025-07-24T16:59:38Z
Sharparam
284703
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Lower ==
[[File:Monastery (Lower).png|thumb|The lower monastery as depicted in the game's relocation menu.|alt=Artwork showing the long bridge in the lower Monastery where the player starts.]]
{{Quote
| A rusted, skeletal bridge precariously connects two towering structures high above a chaotic maze of crumbling buildings
}}
{{clear}}
== Upper ==
[[File:Monastery (Upper).png|thumb|The upper monastery as depicted in the game's relocation menu.|alt=Artwork showing a scene from the upper monastery. The actual monastery building where the area's boss is can be seen in the background.]]
{{Quote
| Perched atop a jagged cliff, the ancient monastery, with its weathered stone walls and moss-covered spires. Serene isolation amidst the surrounding chaos.
}}
{{Navbox/Locations}}
[[Category:Locations]]
c45661f5fc6c65355deb9f8c90263eb72574a274
Uranopolis
0
352
466
2025-07-24T17:07:39Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
'''Uranopolis''' is a location in {{BFF}}.
== Sub-locations ==
Uranopolis consists of two sub-locations: Tower Complex and {{TODO}}.
=== Tower Complex ===
{{Main|Uranopolis/Tower Complex}}
[[File:Uranopolis (Tower Complex).png|thumb|The tower complex as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Tower Complex area.]]
The '''Tower Complex''' is the first sub-location encountered by the player.
{{clear}}
=== Lone Tower ===
[[File:Uranopolis (Lone Tower).png|thumb|The lone tower as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Lone Tower area. The towers housing the area's boss as well as the recalibration "eye" can be seen.]]
The '''Lone Tower''' is the second sub-location encountered by the player. The area's boss – [[Nurgei the Blademaster]] – can be found here.
{{Navbox/Locations}}
[[Category:Locations]]
fc3e22f798adfdd04bd6befa151ccc23aa80ecd5
Locations
0
351
464
2025-07-24T17:08:00Z
Sharparam
284703
Created page with "{{Navbox/Locations}}"
wikitext
text/x-wiki
{{Navbox/Locations}}
980e15253d6e4f1418e9efa737c209de74f57252
Blok 6147
0
353
468
2025-07-24T17:25:02Z
Sharparam
284703
Add quote from relocation menu
wikitext
text/x-wiki
[[File:Blok 6147.png|thumb|Blok 6147 as depicted in the game's relocation menu.|alt=Artwork showing the central area in Blok 6147.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A vast ringed and radial expanse of intricate concrete architecture, adorned with grand archways, ornate carvings, and timeworn {{sic|hide=y|expected=time-worn}} structures that narrate centuries of rich history.
}}
== Trivia ==
* If the game is saved while in Blok 6147, the location listed on the save file will be "Blok 6174". This is presumably a typo as the location is referred to as Blok 6147 in both the pause menu and [[Homunculus]] relocation list.
{{Navbox/Locations}}
[[Category:Locations]]
bda6e533357582f201b31b2a208855d0bdc73471
Rain District
0
355
472
2025-07-24T17:29:27Z
Sharparam
284703
Fix link typo
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Sewers ==
[[File:Rain District (Sewers).png|thumb|The rain district sewers as depicted in the game's relocation menu.|alt=Artwork showing the sewers in the rain district.]]
{{Quote
| A maze of flooded tunnels with murky water that echoes the constant patter of rain from above, walls slick with moss and grime, and a stench of decay that ingles with the distant roar of rushing water and the occasional scurrying of unseen creatures.
}}
{{clear}}
== Center ==
[[File:Rain District (Center).png|thumb|The rain district center as depicted in the game's relocation menu.|alt=Artwork showing the center room in the rain district.]]
{{Quote
| A residential area lying in perpetual rain. Its dilapidated buildings stand silent and forlorn, windows shattered, rooftops caved in, walls rotting with mold. The relentless downpour
}}
{{Navbox/Locations}}
[[Category:Locations]]
411486cc02e286f1982f8922cb1e84ebe86d13e4
Deluge
0
356
474
2025-07-24T17:32:11Z
Sharparam
284703
Created page with "[[File:Deluge.png|thumb|Deluge as depicted in the game's relocation menu.|alt=Artwork showing the Deluge area filled with water with structures lining the sides.]] '''{{PAGENAME}}''' is a location in {{BFF}}. {{Quote | A vast reservoir stretches out like a somber mirror, its surface eerily still, broken only by the faintest ripples. Shadowy shapes drift beneath the dark water, their forms indistinct and haunting. }} {{Navbox/Locations}} [[Category:Locations]]"
wikitext
text/x-wiki
[[File:Deluge.png|thumb|Deluge as depicted in the game's relocation menu.|alt=Artwork showing the Deluge area filled with water with structures lining the sides.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| A vast reservoir stretches out like a somber mirror, its surface eerily still, broken only by the faintest ripples. Shadowy shapes drift beneath the dark water, their forms indistinct and haunting.
}}
{{Navbox/Locations}}
[[Category:Locations]]
693a79d49e7efc3474fef04a49a6ecfcf873ac1f
Asylum
0
357
476
2025-07-24T17:35:03Z
Sharparam
284703
Created page with "[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]] '''{{PAGENAME}}''' is a location in {{BFF}}. {{Quote | The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls. }} {{Navbox/Locations}} Category:Loca..."
wikitext
text/x-wiki
[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls.
}}
{{Navbox/Locations}}
[[Category:Locations]]
37e0b512f0b81e8f301b3b2858e9d4da7562c26f
Upper Blocks
0
358
478
2025-07-24T17:37:37Z
Sharparam
284703
Created page with "[[File:Upper Blocks.png|thumb|Upper Blocks as depicted in the game's relocation menu.|alt=Artwork showing the tall buildings that make up the upper blocks.]] '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}. {{Quote | The abandoned residential and industrial sector is silent, with decaying buildings and rusting machinery shrouded in a heavy layer of dust and cobwebs. Overgrown vines and weeds cling to the crumbling facades, while the occasional gust of wind sti..."
wikitext
text/x-wiki
[[File:Upper Blocks.png|thumb|Upper Blocks as depicted in the game's relocation menu.|alt=Artwork showing the tall buildings that make up the upper blocks.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| The abandoned residential and industrial sector is silent, with decaying buildings and rusting machinery shrouded in a heavy layer of dust and cobwebs. Overgrown vines and weeds cling to the crumbling facades, while the occasional gust of wind stirs the remnants of a once-bustling area, now frozen in time and isolation.
}}
{{Navbox/Locations}}
[[Category:Locations]]
8eb05dbbf1b2eca301ec7824369953ecf59627e8
Ghost Town
0
359
480
2025-07-24T17:41:48Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}. == Floor 13 == [[File:Ghost Town (Floor 13).png|thumb|The 13th floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing a view down a tall shaft in Ghost Town, stairs lining the walls.]] {{Quote | Crumbling, dilapidated buildings shrouded in mist. Faded, peeling paint reveals dark stains on the decaying facades – the area is haunted by the whispers of its forgotten past. }} {{clear}..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Floor 13 ==
[[File:Ghost Town (Floor 13).png|thumb|The 13th floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing a view down a tall shaft in Ghost Town, stairs lining the walls.]]
{{Quote
| Crumbling, dilapidated buildings shrouded in mist. Faded, peeling paint reveals dark stains on the decaying facades – the area is haunted by the whispers of its forgotten past.
}}
{{clear}}
== Floor 1 ==
[[File:Ghost Town (Floor 1).png|thumb|The 1st floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing an outside scene in Ghost Town depicting several high-rise residential buildings.]]
{{Quote
| A decrepit graveyard sprawls with uneven, weather-beaten tombstones. Sunken graves, choked with tangled weeds. Rusted tracks stretch out into the darkness, and the empty ticket counters and derelict waiting rooms are cloaked in fog.
}}
{{Navbox/Locations}}
[[Category:Locations]]
de022882ea75493bf878521b5de2b72ab78ee421
Machinarium
0
360
482
2025-07-24T17:44:46Z
Sharparam
284703
Created page with "[[File:Machinarium.png|thumb|Machinarium as depicted in the game's relocation menu.|alt=Artwork showing an area in the Machinarium: A short walkway leading to a small building. In the background can be seen taller structures with bridges between them.]] '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}. {{Quote | Rusted machinery and oil-slicked floors are interspersed with tarnished religious relics, like ancient statues and faded icons, which add a somber cont..."
wikitext
text/x-wiki
[[File:Machinarium.png|thumb|Machinarium as depicted in the game's relocation menu.|alt=Artwork showing an area in the Machinarium: A short walkway leading to a small building. In the background can be seen taller structures with bridges between them.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Rusted machinery and oil-slicked floors are interspersed with tarnished religious relics, like ancient statues and faded icons, which add a somber contrast yet subtly complement the mechanical decay.
}}
{{Navbox/Locations}}
[[Category:Locations]]
bdce97e055f63d9b564bb8af98884bb9353ec5db
Desert
0
361
484
2025-07-24T17:47:25Z
Sharparam
284703
Created page with "[[File:Desert.png|thumb|Desert as depicted in the game's relocation menu.|alt=Artwork showing the large palace in the desert. The labyrinth can be seen in the background.]] '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}. {{Quote | A dark desert stretches endlessly at the foot of the towering city. Harsh winds whip through the desolate landscape, sending wisps of sand swirling around skeletal remains of old structures. The oppressive silence is occasionally br..."
wikitext
text/x-wiki
[[File:Desert.png|thumb|Desert as depicted in the game's relocation menu.|alt=Artwork showing the large palace in the desert. The labyrinth can be seen in the background.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A dark desert stretches endlessly at the foot of the towering city. Harsh winds whip through the desolate landscape, sending wisps of sand swirling around skeletal remains of old structures. The oppressive silence is occasionally broken by the distant echo of the city's hum.
}}
{{Navbox/Locations}}
[[Category:Locations]]
7a4e1dcb94c588a7cbdfa9c4abb1a9303a8d2d79
Desert Mirage
0
362
486
2025-07-24T17:49:33Z
Sharparam
284703
Created page with "[[File:Desert Mirage.png|thumb|Desert Mirage as depicted in the game's relocation menu.|alt=Artwork showing the desert mirage. The entrance building can be seen on the left, with several towers in the background.]] '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}. {{Quote | A desert from another time. }} {{Navbox/Locations}} [[Category:Locations]]"
wikitext
text/x-wiki
[[File:Desert Mirage.png|thumb|Desert Mirage as depicted in the game's relocation menu.|alt=Artwork showing the desert mirage. The entrance building can be seen on the left, with several towers in the background.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A desert from another time.
}}
{{Navbox/Locations}}
[[Category:Locations]]
b77e5799a2dcb88ca21171824a322e70e1ceed2f
Anomaly (location)
0
363
488
2025-07-24T17:51:11Z
Sharparam
284703
Created page with "[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]] The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}. {{Quote | Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still. }} {{Navbox/Locations}} [[Category:Locations]]"
wikitext
text/x-wiki
[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]]
The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still.
}}
{{Navbox/Locations}}
[[Category:Locations]]
a8fc6f2bc209173c6c2c5d3d178232dfb1ed8321
Template:Navbox/Data logs
10
290
362
361
2025-07-24T19:24:27Z
Sharparam
284703
Add [[The Grave Predicament]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[The Structure]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
82537fe78e3a074ce9313e77c8a0e10fbcd07289
363
362
2025-07-24T19:39:55Z
Sharparam
284703
Add [[Kaleidoscope of Dreams]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
d27f6dedb12199ea9906176abf11a31e884cfb4e
364
363
2025-07-24T20:35:41Z
Sharparam
284703
Add [[Vermillion]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
61fdff8b80c1427da5886fa5b73c6c586e088a1d
365
364
2025-07-25T00:26:24Z
Sharparam
284703
Add [[A Broken Reality]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[A Broken Reality]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
1f8888031e5a5d1097cb7190e22eb472ab1ec16f
366
365
2025-07-26T16:46:43Z
Sharparam
284703
Add [[Understanding]]
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[A Broken Reality]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[Understanding]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
09b921cd27b38e22701e9064c302db0e3c8d90f3
The Grave Predicament
0
392
546
2025-07-24T19:29:54Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |The Administration, a dominant force within this tangled system, exhibits a deeper grasp of [[Omnistructure|the Omnistructure's]] workings compared to other entities. However, its own nature is so enigmatic that it seems to be more an emergent symptom of [[Omnistructure|the Omnistructure]] than a genuine part of it. The Administration's methods and motivations are..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|The Administration, a dominant force within this tangled system, exhibits a deeper grasp of [[Omnistructure|the Omnistructure's]] workings compared to other entities. However, its own nature is so enigmatic that it seems to be more an emergent symptom of [[Omnistructure|the Omnistructure]] than a genuine part of it. The Administration's methods and motivations are as elusive as [[Omnistructure|the Omnistructure]] itself, blending seamlessly into the very fabric of the mysterious domain it governs within it. Its presence, while influential, only adds to the overall complexity of [[Omnistructure|the Omnistructure]], reinforcing the idea that understanding this colossal construct may forever remain an elusive, if not an impossible, pursuit. Nevertheless we must try. Our very survival hinges on our ability to adapt, and without understanding at the very least our immediate surroundings in this labyrinth, we have no room to elude the ever-pursuing peril that surrounds us.
}}
== Location ==
{{coords|4404|1793|-1412}}
Located on an edge overlooking the labyrinth in the [[Anomaly]] area, just after [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius']] boss arena. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
4a149e96e2d9c362546ae535afb986f4d6e1cb03
Blessed Crosier
0
508
780
2025-07-24T19:32:37Z
Sharparam
284703
Created page with "{{Infobox/Weapon | title = {{PAGENAME}} | image = Blessed Crosier.png | Type = Staff | Damage type = Technomancy | Speed = Slow | Abilities = Escape Velocity, Energy Burst | Mk3_Damage_min = 173 | Mk3_Damage_max = 177 }} '''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}. == Acquisition == Dropped by [[Archinquisitor Belisarius (boss)]]. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Blessed Crosier.png
| Type = Staff
| Damage type = Technomancy
| Speed = Slow
| Abilities = Escape Velocity, Energy Burst
| Mk3_Damage_min = 173
| Mk3_Damage_max = 177
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}.
== Acquisition ==
Dropped by [[Archinquisitor Belisarius (boss)]].
{{Navbox/Weapons}}
d1d557ec6a9700fda1ee5579a6f5c4cf86cd912f
Kaleidoscope of Dreams
0
393
548
2025-07-24T19:42:40Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |[[Anomaly|The anomaly]] represents a profound and dangerous space-time phenomenon, its expanding radius a constant threat to the stability and integrity of the entire structure. Its presence is a reminder of the fragility of order in the face of an unrelenting, chaotic force that plagues [[Omnistructure|the Omnistructure]], erasing all that it touches. }} == Loca..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|[[Anomaly|The anomaly]] represents a profound and dangerous space-time phenomenon, its expanding radius a constant threat to the stability and integrity of the entire structure. Its presence is a reminder of the fragility of order in the face of an unrelenting, chaotic force that plagues [[Omnistructure|the Omnistructure]], erasing all that it touches.
}}
== Location ==
{{coords|5310|2116|-1450}}
Found in the [[Anomaly]] area, located right in front of the anomaly itself at the final part of the labyrinth.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
e9b3658c5073f52f9811e41c238dc70edd1b8e24
Template:Navbox/Locations
10
293
379
378
2025-07-24T19:50:02Z
Sharparam
284703
Add [[Unknown]]
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]] ([[Monastery#Lower|Lower]] · [[Monastery#Upper|Upper]])
* [[Blok 6147]]
* [[Rain District]] ([[Rain District#Sewers|Sewers]] · [[Rain District#Center|Center]])
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]] ([[Uranopolis#Tower Complex|Tower Complex]] · [[Uranopolis#Lone Tower|Lone Tower]])
* [[Ghost Town]] ([[Ghost Town#Floor 13|Floor 13]] · [[Ghost Town#Floor 1|Floor 1]])
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
* [[Unknown]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
707b7f5a5cdc0a7291104d9690755ad1acb0d8ea
380
379
2025-07-24T20:11:37Z
Sharparam
284703
Add [[Vermillion Fields]]
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]] ([[Monastery#Lower|Lower]] · [[Monastery#Upper|Upper]])
* [[Blok 6147]]
* [[Rain District]] ([[Rain District#Sewers|Sewers]] · [[Rain District#Center|Center]])
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]] ([[Uranopolis#Tower Complex|Tower Complex]] · [[Uranopolis#Lone Tower|Lone Tower]])
* [[Ghost Town]] ([[Ghost Town#Floor 13|Floor 13]] · [[Ghost Town#Floor 1|Floor 1]])
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
* [[Unknown]]
* [[Vermillion Fields]] ([[Vermillion Fields#Plaza|Plaza]])
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
df2290162f33b6947a33876ca7a91148393a2506
381
380
2025-07-24T20:24:01Z
Sharparam
284703
Fix link to Unknown
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]] ([[Monastery#Lower|Lower]] · [[Monastery#Upper|Upper]])
* [[Blok 6147]]
* [[Rain District]] ([[Rain District#Sewers|Sewers]] · [[Rain District#Center|Center]])
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]] ([[Uranopolis#Tower Complex|Tower Complex]] · [[Uranopolis#Lone Tower|Lone Tower]])
* [[Ghost Town]] ([[Ghost Town#Floor 13|Floor 13]] · [[Ghost Town#Floor 1|Floor 1]])
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
* [[Unknown (location)|Unknown]]
* [[Vermillion Fields]] ([[Vermillion Fields#Plaza|Plaza]])
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
fce3ea1b70826b4182d9c45e9139ae61473c389b
382
381
2025-07-25T00:58:26Z
Sharparam
284703
Add Vermillion Fields Temple sub-location
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]] ([[Monastery#Lower|Lower]] · [[Monastery#Upper|Upper]])
* [[Blok 6147]]
* [[Rain District]] ([[Rain District#Sewers|Sewers]] · [[Rain District#Center|Center]])
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]] ([[Uranopolis#Tower Complex|Tower Complex]] · [[Uranopolis#Lone Tower|Lone Tower]])
* [[Ghost Town]] ([[Ghost Town#Floor 13|Floor 13]] · [[Ghost Town#Floor 1|Floor 1]])
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
* [[Unknown (location)|Unknown]]
* [[Vermillion Fields]] ([[Vermillion Fields#Plaza|Plaza]] · [[Vermillion Fields#Temple|Temple]])
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
7716644faea4dd5aee763d21d89daca0de53c69c
Unknown (location)
0
365
492
2025-07-24T20:21:48Z
Sharparam
284703
Created page with "{{About|the [[Locations|location]]|the [[Bosses|boss]]|Unknown (boss)}} '''Unknown''' is a [[Locations|location]] in {{BFF}}. == Overview == As the Unknown cannot be relocated to, it has no artwork image and no in-game description. {{Navbox/Locations}} [[Category:Locations]]"
wikitext
text/x-wiki
{{About|the [[Locations|location]]|the [[Bosses|boss]]|Unknown (boss)}}
'''Unknown''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
As the Unknown cannot be relocated to, it has no artwork image and no in-game description.
{{Navbox/Locations}}
[[Category:Locations]]
351676f2dfc783d43a014b11a690031ea946e2b8
Unknown
0
366
494
2025-07-24T20:23:30Z
Sharparam
284703
Fix missing paren
wikitext
text/x-wiki
'''Unknown''' may refer to:
== Common meanings ==
* [[Unknown (location)]], the location with the platforming puzzles leading to an optional boss.
* [[Unknown (boss)]], the boss enemy that can be optionally fought in the location sharing its name.
{{Disambiguation}}
a972049d778c73207104b07ad235871c7a53466d
Unknown (boss)
0
549
858
2025-07-24T20:25:53Z
Sharparam
284703
Specify boss is optional
wikitext
text/x-wiki
{{About|the [[Bosses|boss]]|the [[Locations|location]]|Unknown (location)}}
{{Infobox/Boss
| title = Unknown
| image = Unknown (boss).png
}}
'''Unknown''' is an optional [[Bosses|boss]] in {{BFF}}.
== Overview ==
The Unknown resembles the player character in [[armor]], but uses its own [[Weapons|weapon]] instead of mirroring the player's. It does not drop its weapon on defeat.
Upon defeating the boss, the player is immediately transported to [[Vermillion Fields]].
== Location ==
Located at the end of the [[Unknown (location)|Unknown]], being the boss of the area.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
08cbc1e8f1d754f6cc8e5e04d59cc388bc187d8f
Archinquisitor Belisarius (boss)
0
548
856
2025-07-24T20:26:12Z
Sharparam
284703
Fix name
wikitext
text/x-wiki
{{About|the [[Bosses|boss]]|the [[NPC]]|Archinquisitor Belisarius}}
{{Infobox/Boss
| title = Archinquisitor Belisarius
| image = Archinquisitor Belisarius (boss).png
}}
'''Archinquisitor Belisarius''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|4315|1734|-1413}} (approximate)
Found at the beginning of the [[Anomaly]] area.
== Drops ==
* [[Blessed Crosier]]
* [[Unstable Perk Essence]]
* [[Upgrade Module]]
== Quotes ==
=== Upon engaging him ===
{{Quote
|Well well… You made it through. As much as I hate to elevate your spiteful existence to the height of the truth… this is where we are now.
Ever since you've joined us, all you've done is fulfil the goals of the disgusting administration you work for.
The mundane pursuit of tasks is all you know… and this crusade against that apostate filth at the gate is just a backdrop to your performance.
Yet [[Anomaly|the anomaly]] is a blessing I will not let slip out of my hands… for it is instrumental in aiding the God-Emperor, noble is he and eternal, to finally transcend.
Nothing will stand in that path, I assure you. Not the Serdars, not [[Yaroslav]] and definitely not you – a dog that obeys by reflex instead of will.
Now… we both know you never quite die – so you'll at least find out what an eternity of pain is made of. Good thing you have no name – those make for the best martyrs.
}}
{{Navbox/Bosses}}
73a24d629934b27f74f10c58c9ab9e02ed3858bc
Vermillion
0
394
550
2025-07-24T20:47:54Z
Sharparam
284703
Improve location description
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|An omnipresent presence bathed everything in a deep vermillion{{note|"Vermillion" here refers to the color, although it might be more commonly spelled as "vermilion" (with only one L).}} hue. This color created an overwhelming sense of order. The vermillion presence exuded a serene yet unsettling stillness, embodying an ideal form of tranquility. It seemed to impose a perfect structure on the disarray around it, its calm nature hiding an underlying menace. The more you focused on the vermillion form, the more it became clear that this serenity was a guise, concealing a power that could shatter the delicate balance at play.
}}
== Location ==
{{coords|483|-4883|1752}}
Found in the [[Vermillion Fields]], on top of a balcony with a [[Vermillion Knight]] guarding it. Standing at the [[Homunculus]], face the direction of [[The Handler]] and the balcony can be seen behind her.
== See also ==
* [[Vermillion Fields]], for the endgame location
* [[Vermillion Knight]], for the enemy
== Notes ==
{{notelist}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
989e673b86ad80578a904518b93dcddaf305e173
A Broken Reality
0
395
552
2025-07-25T00:29:06Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote |The landscape is filled with soothing, warm tones that evoke a sense of perfect calm and harmony. Yet, despite the stunning serenity, there is an unshakable feeling of not being alone, a subtle but persistent awareness that something else is present. }} == Location == {{coords|2368|-5079|1225}} Found in [[Vermillion Fields]]. Start at the [[Homunculus]] and walk..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|The landscape is filled with soothing, warm tones that evoke a sense of perfect calm and harmony. Yet, despite the stunning serenity, there is an unshakable feeling of not being alone, a subtle but persistent awareness that something else is present.
}}
== Location ==
{{coords|2368|-5079|1225}}
Found in [[Vermillion Fields]]. Start at the [[Homunculus]] and walk to where the blue lightsaber knight is. Head outside from there and get to the edge. Take a left and follow the edge until you come to a balcony on the right with the data log. Use [[Scanner|the scanner]] to help you find it more easily.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
cb804aedc9c441989a2f08a03652278a42ce02a8
Vermillion Fields
0
364
490
2025-07-25T00:56:04Z
Sharparam
284703
Add temple location
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
Upon reaching '''Vermillion Fields''', all previous [[locations]] become inaccessible and are no longer shown in the relocation menu of the [[Homunculus|homunculi]].
== Plaza ==
[[File:Vermillion Fields (Plaza).png|thumb|The Vermillion Fields plaza as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields plaza, an outdoors scene with red foliage and the circular center structure seen on the left.]]
{{Quote
|Forms standing out sharply against the striking vermillion landscape. A sea of fiery hues stretch endlessly. A familiar structure looms over the field.
}}
{{clear}}
== Temple ==
[[File:Vermillion Fields (Temple).png|thumb|The Vermillion Fields temple as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields temple.]]
{{Quote
|Perched atop the [[Vermillion Fields|vermillion fields]], the monastery rises as a monolithic, stunning structure with grand, sweeping arches and intricate carvings. Its imposing presence is both serene and majestic, standing out against the vibrant landscape with a timeless, ethereal beauty. A poetry in shapes.
}}
{{Navbox/Locations}}
[[Category:Locations]]
71f1f17927909020242b8cf472a7e2f89199d643
Template:Navbox/Weapons
10
438
636
2025-07-25T01:14:14Z
Sharparam
284703
Add [[Valtiel]]
wikitext
text/x-wiki
<!-- Weapons must be listed in alphabetical order! -->
{{Navbox
| {{{1|}}}
| template = Navbox/Weapons
| title = [[Weapons]]
| group1 = [[One-handed weapons|One-handed]]
| list1 =
* [[Arming Sword]]
* [[Industrial Axe]]
* [[Industrial Mace]]
* [[Iron Pipe]]
* [[Longsword]]
* [[Machinist's Hammer]]
* [[Morning Star]]
* [[Paladin Mace]]
* [[Ratagan Sabre]]
* [[Scimitar]]
* [[Soul Breaker]]
* [[Tire Iron]]
* [[Torch]]
* [[Woodchopper]]
| group2 = [[Two-handed weapons|Two-handed]]
| list2 =
* [[Anastasia]]
* [[Claymore]]
* [[Faussart]]
* [[Halberd]]
* [[Mechanical Tenderizer]]
* [[Nodachi]]
* [[Royal Claymore]]
* [[Rusty Claymore]]
* [[Solaris]]
* [[Soul Reaper]]
* [[Valtiel]]
| group2.1 = [[Dual Wields]]
| list2.1 =
* [[Blades of Atropos]]
* [[Daggers]]
* [[Kamas]]
* [[Katanas]]
* [[Khopeshs]]
* [[Lacerators]]
| group2.2 = [[Twinblades]]
| list2.2 =
* [[Twinblade]]
| group2.3 = [[Greatweapons]]
| list2.3 =
* [[Armor Buster]]
* [[Divine Greataxe]]
* [[Eviscerator]]
* [[Greathammer]]
| group3 = [[Ranged weapons|Ranged]]
| group3.1 = [[Longbows]]
| list3.1 =
* [[Arcane Bow]]
* [[Longbow]]
* [[Taskmaster]]
* [[Winged bow]]
| group3.2 = [[Staves]]
| list3.2 =
* [[Asklepios]]
* [[Blessed Crosier]]
* [[Evolved Staff]]
* [[Mechanomad Staff]]
* [[Vermillion Staff]]
}}<noinclude>{{Documentation}}</noinclude>
441db50a6ddfe17d473822864f9d20f3a2af385f
Valtiel
0
504
772
2025-07-25T01:15:53Z
Sharparam
284703
Created page with "{{Infobox/Weapon | title = {{PAGENAME}} | image = Valtiel.png | Type = Two-handed | Damage type = Sharp | Speed = Slow | Abilities = Syphon Life, Carnage | Mk3_Damage_min = 522 | Mk3_Damage_max = 562 }} '''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}. == Acquisition == Drops from [[Vermillion Knight|Vermillion Knights]]. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Valtiel.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Syphon Life, Carnage
| Mk3_Damage_min = 522
| Mk3_Damage_max = 562
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Acquisition ==
Drops from [[Vermillion Knight|Vermillion Knights]].
{{Navbox/Weapons}}
cd2852971f9cc25db419ef806fb9c0960f845d16
Template:Navbox/Amulets
10
441
642
2025-07-25T03:48:01Z
Sharparam
284703
Add [[Tactician's Amulet]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Amulets
| title = [[Amulets]]
| list1 =
* [[Amulet of Arcane Protection]]
* [[Amulet of Evasion]]
* [[Tactician's Amulet]]
}}
52e610bdb0cd1e26a433d4a731efea2e044132e1
Tactician's Amulet
0
518
799
2025-07-25T03:49:52Z
Sharparam
284703
Created page with "{{Infobox/Amulet | title = {{PAGENAME}} | image = Tactician's Amulet.png | Effects = Removes invincibility frames | Passives = Vulnerable Dodge }} '''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}. {{Navbox/Amulets}}"
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Tactician's Amulet.png
| Effects = Removes invincibility frames
| Passives = Vulnerable Dodge
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
{{Navbox/Amulets}}
8032681e4f4e42a1fa5445d736a503ae40145d42
Plagued Warden
0
545
850
2025-07-26T15:59:31Z
Sharparam
284703
Add note on spawning
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Plagued Warden.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|2395|-2410|529}} (approximate)
Located in [[Blok 6147]]. After getting off the [[subway]], take the path leading up and then take the stairs on the left. You will see a platform nearby with a spiked shield on the far end. Interacting with the shield spawns the boss, but doing so requires having the [[Plagued Blood]] item in your inventory.
== Drops ==
* [[Spiked Shield]] (only in NG (or if you don't yet have it?))
* [[Anomalous Fragment]] (only in [[NG+]] (or if you don't have the shield?))
{{Navbox/Bosses}}
5dfd44f48ae568136e010129ccbd00bbd7c71a55
Plagued Blood
0
422
606
2025-07-26T16:00:18Z
Sharparam
284703
Add usage
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Plagued Blood.png
| Description = Harvested from a burial site, this unsettling vial contains a sample of plagued blood belonging to a Revenant.
}}
== Location ==
{{coords|-3898|1671|1585}}
Located at the top of the big tower in [[Asylum|the asylum]], after climbing a staircase into a room with a bunch of empty bookshelves, look to your right to see the item on a table.
== Usage ==
Having this item in your inventory allows for spawning some optional bosses.
* [[Plagued Warden]]
* [[Plagued Revenant]]
{{Navbox/Items}}
[[Category:Essential items]]
1f8d91aaf3bd07906a2a403a6db0b8ae9ee60325
Understanding
0
396
554
2025-07-26T16:46:12Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}. == Overview == {{Quote | Hierarchies within various organizations reflect a fragmented understanding of the [[Omnistructure]]. These organizations, though structured, are plagued by slow progress and sporadic breakthroughs. Their efforts to decode and rebuild within this immense and confounding realm are hindered by the overwhelming scale and shifting nature of their environment }} == A..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
| Hierarchies within various organizations reflect a fragmented understanding of the [[Omnistructure]]. These organizations, though structured, are plagued by slow progress and sporadic breakthroughs. Their efforts to decode and rebuild within this immense and confounding realm are hindered by the overwhelming scale and shifting nature of their environment
}}
== Acquisition ==
Unlocked upon speaking to [[Inquisitor Commander Alexius]] for the first time.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
58629768126fce5c895113d20c5c3433807829d2
Template:Navbox/Rings
10
292
375
374
2025-07-26T16:49:00Z
Sharparam
284703
Add [[Ring of Hawk]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
* [[Ring of Hawk]]
* [[Ring of Rammstein]]
* [[Ring of Lesser Talent]]
* [[Ring of Talent]]
* [[Ring of Exceeding Talent]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
a26fb4e5bb5097e037bde34bbe50c7f6f0fd3453
Plagued Nemesis
0
542
844
2025-07-26T16:59:34Z
Sharparam
284703
Add drop
wikitext
text/x-wiki
{{Infobox/Boss
| image = Plagued Nemesis.png
| SharpResist = 32
| BluntResist = 2
| TechnomancyResist = 50
}}
'''{{PAGENAME}}''' is an optional [[boss]] [[Enemies|enemy]] in {{BFF}}.
== Location ==
Found at the top of the big tower in [[Asylum|the asylum]].
== Drops ==
* [[Khopeshs]]
* [[Unstable Perk Essence]]
* [[Upgrade Module]]
* [[Anomalous Fragment]] (Only in [[NG+]])
{{Navbox/Bosses}}
3ab22950bbea5ef8c5c7eecf9db701cacb0006a0
Anomalous Fragment
0
426
614
2025-07-26T17:52:32Z
Sharparam
284703
Update acquisition
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Anomalous Fragment.png
| Description = [[The Handler|Handler]] may convert it to a more useful form.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Acquisition ==
Drops from [[bosses]] in [[NG+]].
== Usage ==
Used to manufacture [[Greater Anomalous Crystal|Greater Anomalous Crystals]] at [[The Handler]].
[[Category:Essential items]]
7980e000ddcb82018f50487ce22ffa9df9abbde2
Nurgei the Blademaster
0
544
848
2025-07-26T17:52:58Z
Sharparam
284703
Add drop
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Nurgei the Blademaster.png
| SharpResist = 29
| BluntResist = 37
| TechnomancyResist = 57
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] [[Enemies|enemy]] in {{BFF}}.
== Location ==
{{coords|1138|-9288|1571}} (approximate)
Found in [[Uranopolis#Lone Tower|Uranopolis (Lone Tower)]]. From the [[Homunculus]], walk across the long bridge lined with pillars and you will see him straight ahead in his boss arena.
== Drops ==
* [[Upgrade Module]]
* [[Nodachi]]
* [[Unstable Perk Essence]]
* [[Anomalous Fragment]] ([[NG+]])
{{Navbox/Bosses}}
1f8634a99af6d189e90d0e6283c284736ffbd4fe
Old Key
0
429
620
2025-07-26T18:04:43Z
Sharparam
284703
Created page with "{{Infobox/Item | title = {{PAGENAME}} | image = Old Key.png | Description = An old, rusted key that unlocks the gate in the old [[Monastery|monastery]]. }} '''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}. == Location == {{coords|19328.57|-41596.65|3.83}} Found at the top of the [[Monastery]], behind [[Konrad the Traitor]]. Killing the boss is not required to pick it up. == Usage == Unlocks the gate at the top of the [[Monastery]], found near t..."
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Old Key.png
| Description = An old, rusted key that unlocks the gate in the old [[Monastery|monastery]].
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Location ==
{{coords|19328.57|-41596.65|3.83}}
Found at the top of the [[Monastery]], behind [[Konrad the Traitor]]. Killing the boss is not required to pick it up.
== Usage ==
Unlocks the gate at the top of the [[Monastery]], found near the entrance to [[Konrad the Traitor|Konrad the Traitor's]] boss arena (keep going past the entrance instead of entering it).
{{Navbox/Items}}
a6c6a09cf952e26c4386195a47267f9112b2ac5e
Konrad the Traitor
0
550
860
2025-07-26T18:04:55Z
Sharparam
284703
Created page with "{{Infobox/Boss | title = {{PAGENAME}} | image = Konrad the Traitor.png }} '''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}. == Overview == The boss is not mandatory for progression, as the [[Old Key]] can be looted off the ground behind him. However, skipping him means not having access to [[Homunculus Mirage]], as the husk drops from him (including in [[NG+]]). == Location == {{coords|18794.39|-40662.96|-15.20}} (approximate) Located at the top of the [..."
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Konrad the Traitor.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}.
== Overview ==
The boss is not mandatory for progression, as the [[Old Key]] can be looted off the ground behind him. However, skipping him means not having access to [[Homunculus Mirage]], as the husk drops from him (including in [[NG+]]).
== Location ==
{{coords|18794.39|-40662.96|-15.20}} (approximate)
Located at the top of the [[Monastery]], being the area's boss.
== Drops ==
* [[Homunculus Mirage Husk]]
* [[Handler Echo]]
* [[Anomalous Fragment]] ([[NG+]])
{{Navbox/Bosses}}
acd47fd792b54614f8d3d42a80fe9037a65997cc
Handler Echo
0
421
604
2025-07-26T18:05:14Z
Sharparam
284703
Add konrad drop
wikitext
text/x-wiki
{{Infobox/Item
| image = Handler Echo.png
| title = {{PAGENAME}}
| Description = An obscure residue used to supplement [[The Handler|the Handler's]] capabilities. [[The Handler]] can use this to upgrade [[equipment]] more effectively.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] used to level up [[The Handler]], in order to increase the max level equipment can be upgraded to.
== Usage ==
If the item is in your inventory, [[The Handler]] will automatically level up when you next interact with her. A message will also pop up in the bottom right corner of the screen informing you of the new synchronization level.
== Acquisition ==
* Drops from [[Konrad the Traitor]].
* Can drop from samurai enemies in [[Uranopolis]] (limited to one drop).
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Rain District]] || Up some stairs. || {{coords|-36697.35|-17753.66|12174.48}}
|-
| [[Asylum]] || In the spiral staircase with the shortcut door to the courtyard there is a floating ghost. Move through the ghost and the echo will be right behind it. || {{coords|-4225|6824|9253}}
|-
| [[Desert]] || In the big building after the sand worm, where Yaroslav's crew is. The echo is sitting on a toppled pillar. || {{coords|3720|1159|-1397}}
|}
{{Navbox/Items}}
[[Category:Essential items]]
8e39742af7d396a0340cfbf20893f0518504a05a
Kamas
0
476
716
2025-07-26T18:41:15Z
Sharparam
284703
Add damage for Mk 4 and 5
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Kamas.png
| Type = Dual Wield
| Speed = Swift
| Damage type = Sharp
| Passives = Powerful Decay
| Abilities = Bladestorm
| Mk3_Damage_min = 112
| Mk3_Damage_max = 130
| Mk4_Damage_min = 269
| Mk4_Damage_max = 313
| Mk5_Damage_min = 308
| Mk5_Damage_max = 358
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
{{Navbox/Weapons}}
80fd6cf0dc6a59c85d7b761b05ed0b0cb9908c27
Daggers
0
478
720
2025-07-26T21:54:12Z
Sharparam
284703
Add min mark
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Daggers.png
| Type = Dual Wield
| Speed = Swift
| Damage type = Sharp
| Abilities = Dual Brutality, Shadowstep
| Mk_min = 2
| Mk2_Damage_min = 106
| Mk2_Damage_max = 123
| Mk3_Damage_min = 135
| Mk3_Damage_max = 157
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Location ==
Located together with the [[sentinel]] [[Armor sets|armor set]] on a corpse in [[Asylum|the asylum]]. See [[Sentinel#Location]] for its location.
{{Navbox/Weapons}}
564b414d6a096a1107d0569379379434b1e1f48e
Template:Plainlist
10
535
830
2025-07-26T22:45:29Z
Sharparam
284703
Created page with "<templatestyles src="Plainlist/styles.css"/><div class="plainlist {{{class|}}}" {{safesubst<noinclude />:#if:{{{style|}}}{{{indent|}}}|style="{{safesubst<noinclude />:#if:{{{indent|}}}|margin-left: {{safesubst<noinclude />:#expr:{{{indent}}}*1.6}}em;}} {{{style|}}}"}}>{{safesubst<noinclude />:#if:{{{1|}}}| {{{1}}} </div>}}<noinclude></div> {{documentation}} </noinclude>"
wikitext
text/x-wiki
<templatestyles src="Plainlist/styles.css"/><div class="plainlist {{{class|}}}" {{safesubst<noinclude />:#if:{{{style|}}}{{{indent|}}}|style="{{safesubst<noinclude />:#if:{{{indent|}}}|margin-left: {{safesubst<noinclude />:#expr:{{{indent}}}*1.6}}em;}} {{{style|}}}"}}>{{safesubst<noinclude />:#if:{{{1|}}}|
{{{1}}}
</div>}}<noinclude></div>
{{documentation}}
</noinclude>
1f83cec6d8a2e5ba45342d554089a71b19afae80
Template:Plainlist/styles.css
10
536
832
2025-07-26T22:45:54Z
Sharparam
284703
sanitized-css
text/css
.plainlist ol,
.plainlist ul {
line-height: inherit;
list-style: none;
margin: 0;
padding: 0; /* Reset Minerva default */
}
.plainlist ol li,
.plainlist ul li {
margin-bottom: 0;
}
15a09febff47c3fa7ff01092a7cd381b44a14427
Template:Infobox/Weapon/doc
10
452
668
2025-07-27T03:00:01Z
Sharparam
284703
Add template data for mk 0
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for weapons",
"params": {
"title": {
"label": "Weapon name",
"description": "The name of the weapon",
"required": false,
"default": "{{PAGENAME}}",
"example": "Cool Sword",
"type": "string"
},
"image": {
"label": "Weapon image",
"description": "Name of the file used as the image for the weapon, should be at least 300 pixels wide.",
"required": true,
"example": "Cool weapon.png",
"type": "wiki-file-name"
},
"Type": {
"label": "Weapon type",
"description": "The type of the weapon.",
"required": true,
"example": "Dual Wields",
"type": "wiki-page-name"
},
"Speed": {
"label": "Weapon speed",
"description": "The speed category of the weapon.",
"required": true,
"example": "Fast",
"type": "string"
},
"Damage type": {
"label": "Weapon damage type",
"description": "The type of damage dealt by the weapon.",
"required": true,
"example": "Sharp",
"type": "wiki-page-name"
},
"Passives": {
"label": "Passive properties",
"description": "Any passive properties the weapon has, comma separated",
"required": false,
"example": "Health Regen, Flux Regen",
"type": "string"
},
"Abilities": {
"label": "Active abilities",
"description": "Active abilities that can be used when the weapon is equipped, comma separated",
"required": false,
"example": "Blade Dance",
"type": "string"
},
"Mk_min": {
"label": "Minimum mark level",
"description": "The initial mark level of the weapon",
"required": false,
"default": "0",
"example": "3",
"type": "number"
},
"Mk0_Damage_min": {
"label": "Min. damage at Mk. 0",
"description": "Minimum damage the weapon deals at Mk. 0",
"required": true,
"example": "5",
"type": "number"
},
"Mk0_Damage_max": {
"label": "Max. damage at Mk. 0",
"description": "Maximum damage the weapon deals at Mk. 0",
"required": true,
"example": "8",
"type": "number"
},
"Mk1_Damage_min": {
"label": "Min. damage at Mk. 1",
"description": "Minimum damage the weapon deals at Mk. 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Damage_max": {
"label": "Max. damage at Mk. 1",
"description": "Maximum damage the weapon deals at Mk. 1",
"required": true,
"example": "8",
"type": "number"
},
"Mk2_Damage_min": {
"label": "Min. damage at Mk. 2",
"description": "Minimum damage the weapon deals at Mk. 2",
"required": true,
"example": "10",
"type": "number"
},
"Mk2_Damage_max": {
"label": "Max. damage at Mk. 2",
"description": "Maximum damage the weapon deals at Mk. 2",
"required": true,
"example": "15",
"type": "number"
},
"Mk3_Damage_min": {
"label": "Min. damage at Mk. 3",
"description": "Minimum damage the weapon deals at Mk. 3",
"required": true,
"example": "20",
"type": "number"
},
"Mk3_Damage_max": {
"label": "Max. damage at Mk. 3",
"description": "Maximum damage the weapon deals at Mk. 3",
"required": true,
"example": "25",
"type": "number"
},
"Mk4_Damage_min": {
"label": "Min. damage at Mk. 4",
"description": "Minimum damage the weapon deals at Mk. 4",
"required": true,
"example": "30",
"type": "number"
},
"Mk4_Damage_max": {
"label": "Max. damage at Mk. 4",
"description": "Maximum damage the weapon deals at Mk. 4",
"required": true,
"example": "40",
"type": "number"
},
"Mk5_Damage_min": {
"label": "Min. damage at Mk. 5",
"description": "Minimum damage the weapon deals at Mk. 5",
"required": true,
"example": "50",
"type": "number"
},
"Mk5_Damage_max": {
"label": "Max. damage at Mk. 5",
"description": "Maximum damage the weapon deals at Mk. 5",
"required": true,
"example": "60",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Weapon
| title = Cool Sword
| image = Sword_01.svg
| Type = Dual Wields
| Speed = Fast
| Damage type = Sharp
| Passives = Infinite regen,Stuff,Cool
| Abilities = Blade Dance
| Mk_min = 1
| Mk1_Damage_min = 1
| Mk1_Damage_max = 2
| Mk2_Damage_min = 4
| Mk2_Damage_max = 6
| Mk3_Damage_min = 10
| Mk3_Damage_max = 12
| Mk4_Damage_min = 20
| Mk4_Damage_max = 25
| Mk5_Damage_min = 50
| Mk5_Damage_max = 60
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Weapon
| title = Cool Sword
| image = Sword_01.svg
| Type = Dual Wields
| Speed = Fast
| Damage type = Sharp
| Passives = Infinite regen
| Abilities = Blade Dance
| Mk_min = 1
| Mk1_Damage_min = 1
| Mk1_Damage_max = 2
| Mk2_Damage_min = 4
| Mk2_Damage_max = 6
| Mk3_Damage_min = 10
| Mk3_Damage_max = 12
| Mk4_Damage_min = 20
| Mk4_Damage_max = 25
| Mk5_Damage_min = 50
| Mk5_Damage_max = 60
}}
</syntaxhighlight>
03d55ce17e93a95147326d083a21a60c735a4602
NPCs
0
368
498
2025-07-27T19:31:51Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
'''Non-player characters (NPC)''' are characters in {{BFF}} that can aid the player, provide services, or be spoken to in order to learn more about the world.
== Notable NPCs ==
* [[The Handler]] – Upgrades [[equipment]] and allows for [[crafting]] certain [[items]].
{{Navbox/NPCs}}
79553771fc8e6ca775b99979d35e2de32ae39cbb
Template:Navbox/NPCs
10
294
384
2025-07-27T19:37:46Z
Sharparam
284703
Created page with "{{Navbox | {{{child|}}} | template = Navbox/NPCs | title = [[NPCs]] | list1 = * [[Abandoned Soldier]] * [[Abelard the Brave]] * [[Anselm the Pure]] * [[Archinquisitor Belisarius]] * [[The Handler]] * [[Inquisitor Commander Alexius]] * [[Mysterious Woman]] * [[Royal Division Captain Yulia]] * [[Stranger]] * [[Yaroslav]] }}<noinclude> {{Documentation}} [[Category:Navigation templates]] <noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{child|}}}
| template = Navbox/NPCs
| title = [[NPCs]]
| list1 =
* [[Abandoned Soldier]]
* [[Abelard the Brave]]
* [[Anselm the Pure]]
* [[Archinquisitor Belisarius]]
* [[The Handler]]
* [[Inquisitor Commander Alexius]]
* [[Mysterious Woman]]
* [[Royal Division Captain Yulia]]
* [[Stranger]]
* [[Yaroslav]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
<noinclude>
19819092a7dffc936dc5330f6d3c7764bede86db
Abandoned Soldier
0
400
561
2025-07-27T22:35:50Z
Sharparam
284703
Add infobox and navbox
wikitext
text/x-wiki
{{Infobox/NPC
| image = Abandoned Soldier.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
Found in the [[Monastery#Lower|lower Monastery]], at the top of the stairs sitting next to one of the statue heads ({{coords|22476.39|-66438.91|-8856.44}}).
After defeating [[Konrad the Traitor]], he moves to {{TODO|Add second location}}.
At some point, he disappears entirely from the game.
{{Navbox/NPCs}}
e596f1f08e1e0d7bb6ddf38f363f5924a5b8dd01
Archinquisitor Belisarius
0
401
563
2025-07-27T22:36:32Z
Sharparam
284703
Add infobox and navbox
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Archinquisitor Belisarius (boss)}}
{{stub}}
{{Infobox/NPC
| image = Archinquisitor Belisarius.png
}}
{{Navbox/NPCs}}
7acff4eb5df9236854d4caf127e0613b0980b80d
Inquisitor Commander Alexius
0
402
565
2025-07-27T22:37:16Z
Sharparam
284703
Add infobox and navbox
wikitext
text/x-wiki
{{Infobox/NPC
| image = Inquisitor Commander Alexius.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|-41635.32|9075.12|11831.71}}
Located in the [[Asylum]], in a tower that can be reached by following a hidden path.
== Quotes ==
=== On first meeting ===
{{Quote
|Hmmm – a visitor.
A visitor to a plague at that – a rare occurence{{sic|expected=occurrence}}. Ah! The Administration? Yes – that much is now obvious.
Always a pervasive need for the world to make sense – but with each passing moment, I find the [[omnistructure]] is always one step beyond it… beyond comprehension.
I wonder what tales you'd share if only you could speak. Traversing every crevice and ruin on foot, my, my… the secrets you hold… and what happens to the ones you leave behind? Do you ever think of them?
It sounds like a treacherous life… You must not know much kindness. And how could you – I imagine you've experienced pain and death uncountable times. It is after all reflected in your demeanour.
Maybe this can make a small change. <!-- Gives greater crystals -->
You know, I myself am not a stranger to challenges. This struggle between absolute power and perfect order is no longer easy to balance. I find myself giving it my all, without, seeing much in return…
[[The Serdars]] now complicate things… Their sacrifices were too great for a wavering Empire. Yet rebelling against everything makes life lose its purpose…
[[The Administration|The Administration's]] vision of order is sterile however… perfect, yes, but like marble – its beauty frozen permanently in the rhythm of death. In his few moments of peace, [[Yaroslav]] would probably explain it better than I – then again – his word was always as sharp as his saber.
We both have work to do. Until we meet again.
}}
Unlocks the data log [[Understanding]] and gives you two [[Greater Anomalous Crystal|Greater Anomalous Crystals]].
=== After first encounter ===
{{Quote|We both have work to do. Until we meet again}}
{{Navbox/NPCs}}
39b57600330ffb5ca7e6c437458be303142ceb91
Yaroslav
0
403
567
2025-07-27T22:38:09Z
Sharparam
284703
Add infobox and navbox
wikitext
text/x-wiki
{{Infobox/NPC
| image = Yaroslav.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|3721|1150|-1397}}
Located in the [[Desert]]. Standing with his crew in front of the gate to [[The Anomaly]].
== Quotes ==
=== First encounter ===
{{Quote
|Welcome to [[The Anomaly|the anomaly]]. The dream of uncertainty. Here, even reality amounts to nothing.
Time is not of the essence here… Only choice. Soon, you'll feel it yourself.
Sometimes, I hear it all again. The voice of a girl… The color of her eyes… Frightening yet beautiful… Like mornings at war. Hours before the storm… You breathe in deeply, for it may be your last. The vast sky… And between the cold air and the smoke, a ray of sunshine on your face…
Beyond those gates, you will have to carry the greatest burden of all – your own!
The crusade they've mustered is blind with power… my own kind, crippled by ignorance… we are lost… lost in the wilderness!
I have not seen her for so long, I wonder if she was even real… A daughter imagined in dreams perhaps… Winds be with her.
I too am tired, but I gaze into the fire as it burns slowly – my eyes wide open. Some moths gather around the flame and they fly straight into it. Others fly in too and even more follow… All night long, without as much as a rustle, they melt away… I did not fear death then… but I was beginning to fear for my life.
We enslaved what was left of the Forsaken… We crucified the Mechanomads for raiding time itself… We brought light to darkness and blinded all who refused to see… And even here, at the gates to the anomaly, we flay all who dare approach. You understand such methods… After all, your own path is a river of blood and deception…
When you return, Collector, things will not be as they were. You will not be as you were.
}}
=== After first encounter ===
{{Quote|When you return, Collector, things will not be as they were. You will not be as you were.}}
=== Cutscene when leaving the [[Desert]] to enter the [[Anomaly]] ===
{{Quote
|Things have been set in motion that can never be explained.
An eternal rain is coming our way – remember to trust your blade. You will need it more than ever.
}}
{{Navbox/NPCs}}
6bb0d94919bf2b14a91b7fd37736740fa5038de0
Royal Division Captain Yulia
0
404
569
2025-07-29T12:44:45Z
Sharparam
284703
Created page with "{{About|the [[NPC]]|the [[Bosses|boss]]|Royal Division Captain Yulia & Vermillion Mirage}} {{Infobox/NPC | image = Royal Division Captain Yulia.png }} {{stub}} '''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}. {{Navbox/NPCs}}"
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Royal Division Captain Yulia & Vermillion Mirage}}
{{Infobox/NPC
| image = Royal Division Captain Yulia.png
}}
{{stub}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
{{Navbox/NPCs}}
47c5320bb535502d6ea086d13c44e3827509697f
Vermillion Staff
0
507
778
2025-07-29T20:05:02Z
Sharparam
284703
Specify minimum mark
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Vermillion Staff.png
| Type = Staff
| Damage type = Technomancy
| Speed = Slow
| Abilities = Forceful Repulsion, Quake
| Mk_min = 3
| Mk3_Damage_min = 117
| Mk3_Damage_max = 120
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] weapon in {{BFF}}.
== Location ==
{{coords|1241|-8256|275}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], go through the doorway and take the left path. At the outdoor area with a big staircase leading up, head instead to the right before the staircase, leading to an area with some tombstones. The weapon can be found leaning against a wall in the dead-end.
{{Navbox/Weapons}}
e59fb090f56eced502c56a092f5d2cf9267c2818
Template:DamageRange
10
527
814
2025-07-29T20:07:04Z
Sharparam
284703
Allow using tech as short for technomancy
wikitext
text/x-wiki
<includeonly>{{Tooltip|{{{1}}}–{{{2}}}|Average: {{Average|{{{1}}}|{{{2}}}}}}}{{#if:{{{type|}}}| {{#switch:{{lc:{{{type}}}}}
| sharp = [[Sharp]]
| blunt = [[Blunt]]
| tech
| technomancy = [[Technomancy]]
| #default = {{{type}}}
}}|}}</includeonly><noinclude>{{Documentation}}</noinclude>
bee05e8ca021e7585fc203ed68db91f82ab057e2
Template:Navbox/Armor
10
439
638
2025-07-29T20:28:04Z
Sharparam
284703
Add [[Desert Corp]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Crude Helmet]]
* [[Deserts Respirator Helmet]]
* [[Eris]]
* [[Librarian Hood]]
* [[Plagued Revenant Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Techpriest Helmet]]
| group2 = [[Pauldrons]]
| group3 = [[Chestguards]]
| list3 =
* [[Citadel Warrior Chest]]
* [[Corrupted Cuirass]]
* [[Librarian Overcoat]]
* [[Sentinel Chest]]
| group4 = [[Legguards]]
| list4 =
* [[Librarian Trousers]]
* [[Sentinel Legguard]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>{{Documentation}}</noinclude>
d47fdce5305e2ded83cd423d5b2674c32d0dde4d
Mutated Ghoul
0
552
864
2025-07-30T21:47:33Z
Sharparam
284703
Created page with "{{Infobox/Boss | image = Mutated Ghoul.png }} '''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}. == Location == {{coords|6937.36|-64861.39|-17736.47}} (approximate) Located in a big grass field at the bottom of the [[Monastery]]. == Drops == * [[Anomalous Fragment]] (only in [[NG+]]) {{Navbox/Bosses}}"
wikitext
text/x-wiki
{{Infobox/Boss
| image = Mutated Ghoul.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}.
== Location ==
{{coords|6937.36|-64861.39|-17736.47}} (approximate)
Located in a big grass field at the bottom of the [[Monastery]].
== Drops ==
* [[Anomalous Fragment]] (only in [[NG+]])
{{Navbox/Bosses}}
8e88bd012af5d51d364d79af5fc33127dd67fa4d
Divine Greataxe
0
470
704
2025-07-30T23:09:34Z
Sharparam
284703
Fix coordinates
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Divine Greataxe.png
| Type = Greatweapon
| Damage type = Sharp
| Speed = Sluggish
| Passives = Greater Divine Judgment
| Abilities = Regal Radiance
| Mk4_Damage_min = 597
| Mk4_Damage_max = 656
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
== Location ==
{{coords|43210.37|165132.67|-141105.39}}
Found in the [[Anomaly]]. From the [[Homunculus]], walk past [[The Handler]] and you will see the item up ahead on the ledge of a building.
{{Navbox/Weapons}}
0ae771a14e6b5fd5c63e8a73b5aebd90154e8bff
Abelard the Brave
0
405
571
2025-07-30T23:23:05Z
Sharparam
284703
Created page with "{{Infobox/NPC | image = Abelard the Brave.png }} '''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}. == Location == {{coords|3566.32|32790.88|-14128.63}} Stands on the edge of a platform at the top of the [[Machinarium]]. == Quotes == === First encounter === {{Quote |Gets lonely out here. Thank the [[God-Emperor]] for the voices that haunt me… Who knows what [[Yaroslav]] is up to. To turn on his own… so brutally. Tsss! [[Serdar]] filth! No order to this place. Ther..."
wikitext
text/x-wiki
{{Infobox/NPC
| image = Abelard the Brave.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|3566.32|32790.88|-14128.63}}
Stands on the edge of a platform at the top of the [[Machinarium]].
== Quotes ==
=== First encounter ===
{{Quote
|Gets lonely out here. Thank the [[God-Emperor]] for the voices that haunt me…
Who knows what [[Yaroslav]] is up to. To turn on his own… so brutally. Tsss!
[[Serdar]] filth!
No order to this place. There's no cycle, no ebb and flow to the city. It all feels like… Eh. What do you care anyway.
War is Hell. Not a sewer, so I don't exactly know what you{{note|The voice actor emphasis the "you" in this sentence, but the subtitles do not.}} are doing here.
We all have our role to play. You play yours. We'll see about mine!
Farewell.
}}
=== Upon speaking to him again ===
{{Quote|Farewell.}}
== Notes ==
{{notelist}}
{{Navbox/NPCs}}
bff64714017d7cf963314a972d069174724842aa
Module:Convert
828
720
1103
2025-07-31T20:50:48Z
wikipedia>Ahecht
0
move arg extraction to its own function to allow _convert() to be called from other lua modules
Scribunto
text/plain
-- Convert a value from one unit of measurement to another.
-- Example: {{convert|123|lb|kg}} --> 123 pounds (56 kg)
-- See [[:en:Template:Convert/Transwiki guide]] if copying to another wiki.
local MINUS = '−' -- Unicode U+2212 MINUS SIGN (UTF-8: e2 88 92)
local abs = math.abs
local floor = math.floor
local format = string.format
local log10 = math.log10
local ustring = mw.ustring
local ulen = ustring.len
local usub = ustring.sub
-- Configuration options to keep magic values in one location.
-- Conversion data and message text are defined in separate modules.
local config, maxsigfig
local numdot -- must be '.' or ',' or a character which works in a regex
local numsep, numsep_remove, numsep_remove2
local data_code, all_units
local text_code
local varname -- can be a code to use variable names that depend on value
local from_en_table -- to translate an output string of en digits to local language
local to_en_table -- to translate an input string of digits in local language to en
-- Use translation_table in convert/text to change the following.
local en_default -- true uses lang=en unless convert has lang=local or local digits
local group_method = 3 -- code for how many digits are in a group
local per_word = 'per' -- for units like "liters per kilometer"
local plural_suffix = 's' -- only other useful value is probably '' to disable plural unit names
local omitsep -- true to omit separator before local symbol/name
-- All units should be defined in the data module. However, to cater for quick changes
-- and experiments, any unknown unit is looked up in an extra data module, if it exists.
-- That module would be transcluded in only a small number of pages, so there should be
-- little server overhead from making changes, and changes should propagate quickly.
local extra_module -- name of module with extra units
local extra_units -- nil or table of extra units from extra_module
-- Some options in the invoking template can set variables used later in the module.
local currency_text -- for a user-defined currency symbol: {{convert|12|$/ha|$=€}} (euro replaces dollar)
local function from_en(text)
-- Input is a string representing a number in en digits with '.' decimal mark,
-- without digit grouping (which is done just after calling this).
-- Return the translation of the string with numdot and digits in local language.
if numdot ~= '.' then
text = text:gsub('%.', numdot)
end
if from_en_table then
text = text:gsub('%d', from_en_table)
end
return text
end
local function to_en(text)
-- Input is a string representing a number in the local language with
-- an optional numdot decimal mark and numsep digit grouping.
-- Return the translation of the string with '.' mark and en digits,
-- and no separators (they have to be removed here to handle cases like
-- numsep = '.' and numdot = ',' with input "1.234.567,8").
if to_en_table then
text = ustring.gsub(text, '%d', to_en_table)
end
if numsep_remove then
text = text:gsub(numsep_remove, '')
end
if numsep_remove2 then
text = text:gsub(numsep_remove2, '')
end
if numdot ~= '.' then
text = text:gsub(numdot, '.')
end
return text
end
local function decimal_mark(text)
-- Return ',' if text probably is using comma for decimal mark, or has no decimal mark.
-- Return '.' if text probably is using dot for decimal mark.
-- Otherwise return nothing (decimal mark not known).
if not text:find('[.,]') then return ',' end
text = text:gsub('^%-', ''):gsub('%+%d+/%d+$', ''):gsub('[Ee]%-?%d+$', '')
local decimal =
text:match('^0?([.,])%d+$') or
text:match('%d([.,])%d?%d?$') or
text:match('%d([.,])%d%d%d%d+$')
if decimal then return decimal end
if text:match('%.%d+%.') then return ',' end
if text:match('%,%d+,') then return '.' end
end
local add_warning, with_separator -- forward declarations
local function to_en_with_check(text, parms)
-- Version of to_en() for a wiki using numdot = ',' and numsep = '.' to check
-- text (an input number as a string) which might have been copied from enwiki.
-- For example, in '1.234' the '.' could be a decimal mark or a group separator.
-- From viwiki.
if to_en_table then
text = ustring.gsub(text, '%d', to_en_table)
end
if decimal_mark(text) == '.' then
local original = text
text = text:gsub(',', '') -- for example, interpret "1,234.5" as an enwiki value
if parms then
add_warning(parms, 0, 'cvt_enwiki_num', original, with_separator({}, text))
end
else
if numsep_remove then
text = text:gsub(numsep_remove, '')
end
if numsep_remove2 then
text = text:gsub(numsep_remove2, '')
end
if numdot ~= '.' then
text = text:gsub(numdot, '.')
end
end
return text
end
local function omit_separator(id)
-- Return true if there should be no separator before id (a unit symbol or name).
-- For zhwiki, there should be no separator if id uses local characters.
-- The following kludge should be a sufficient test.
if omitsep then
if id:sub(1, 2) == '-{' then -- for "-{...}-" content language variant
return true
end
if id:byte() > 127 then
local first = usub(id, 1, 1)
if first ~= 'Å' and first ~= '°' and first ~= 'µ' then
return true
end
end
end
return id:sub(1, 1) == '/' -- no separator before units like "/ha"
end
local spell_module -- name of module that can spell numbers
local speller -- function from that module to handle spelling (set if needed)
local wikidata_module, wikidata_data_module -- names of Wikidata modules
local wikidata_code, wikidata_data -- exported tables from those modules (set if needed)
local function set_config(args)
-- Set configuration options from template #invoke or defaults.
config = args
maxsigfig = config.maxsigfig or 14 -- maximum number of significant figures
local data_module, text_module
local sandbox = config.sandbox and ('/' .. config.sandbox) or ''
data_module = "Module:Convert/data" .. sandbox
text_module = "Module:Convert/text" .. sandbox
extra_module = "Module:Convert/extra" .. sandbox
wikidata_module = "Module:Convert/wikidata" .. sandbox
wikidata_data_module = "Module:Convert/wikidata/data" .. sandbox
spell_module = "Module:ConvertNumeric"
data_code = mw.loadData(data_module)
text_code = mw.loadData(text_module)
all_units = data_code.all_units
local translation = text_code.translation_table
if translation then
numdot = translation.numdot
numsep = translation.numsep
if numdot == ',' and numsep == '.' then
if text_code.all_messages.cvt_enwiki_num then
to_en = to_en_with_check
end
end
if translation.group then
group_method = translation.group
end
if translation.per_word then
per_word = translation.per_word
end
if translation.plural_suffix then
plural_suffix = translation.plural_suffix
end
varname = translation.varname
from_en_table = translation.from_en
local use_workaround = true
if use_workaround then
-- 2013-07-05 workaround bug by making a copy of the required table.
-- mw.ustring.gsub fails with a table (to_en_table) as the replacement,
-- if the table is accessed via mw.loadData.
local source = translation.to_en
if source then
to_en_table = {}
for k, v in pairs(source) do
to_en_table[k] = v
end
end
else
to_en_table = translation.to_en
end
if translation.lang == 'en default' then
en_default = true -- for hiwiki
end
omitsep = translation.omitsep -- for zhwiki
end
numdot = config.numdot or numdot or '.' -- decimal mark before fractional digits
numsep = config.numsep or numsep or ',' -- group separator for numbers
-- numsep should be ',' or '.' or '' or ' ' or a Unicode character.
-- numsep_remove must work in a regex to identify separators to be removed.
if numsep ~= '' then
numsep_remove = (numsep == '.') and '%.' or numsep
end
if numsep ~= ',' and numdot ~= ',' then
numsep_remove2 = ',' -- so numbers copied from enwiki will work
end
end
local function collection()
-- Return a table to hold items.
return {
n = 0,
add = function (self, item)
self.n = self.n + 1
self[self.n] = item
end,
}
end
local function divide(numerator, denominator)
-- Return integers quotient, remainder resulting from dividing the two
-- given numbers, which should be unsigned integers.
local quotient, remainder = floor(numerator / denominator), numerator % denominator
if not (0 <= remainder and remainder < denominator) then
-- Floating point limits may need this, as in {{convert|160.02|Ym|ydftin}}.
remainder = 0
end
return quotient, remainder
end
local function split(text, delimiter)
-- Return a numbered table with fields from splitting text.
-- The delimiter is used in a regex without escaping (for example, '.' would fail).
-- Each field has any leading/trailing whitespace removed.
local t = {}
text = text .. delimiter -- to get last item
for item in text:gmatch('%s*(.-)%s*' .. delimiter) do
table.insert(t, item)
end
return t
end
local function strip(text)
-- If text is a string, return its content with no leading/trailing
-- whitespace. Otherwise return nil (a nil argument gives a nil result).
if type(text) == 'string' then
return text:match("^%s*(.-)%s*$")
end
end
local function table_len(t)
-- Return length (<100) of a numbered table to replace #t which is
-- documented to not work if t is accessed via mw.loadData().
for i = 1, 100 do
if t[i] == nil then
return i - 1
end
end
end
local function wanted_category(catkey, catsort, want_warning)
-- Return message category if it is wanted in current namespace,
-- otherwise return ''.
local cat
local title = mw.title.getCurrentTitle()
if title then
local nsdefault = '0' -- default namespace: '0' = article; '0,10' = article and template
local namespace = title.namespace
for _, v in ipairs(split(config.nscat or nsdefault, ',')) do
if namespace == tonumber(v) then
cat = text_code.all_categories[want_warning and 'warning' or catkey]
if catsort and catsort ~= '' and cat:sub(-2) == ']]' then
cat = cat:sub(1, -3) .. '|' .. mw.text.nowiki(usub(catsort, 1, 20)) .. ']]'
end
break
end
end
end
return cat or ''
end
local function message(parms, mcode, is_warning)
-- Return wikitext for an error message, including category if specified
-- for the message type.
-- mcode = numbered table specifying the message:
-- mcode[1] = 'cvt_xxx' (string used as a key to get message info)
-- mcode[2] = 'parm1' (string to replace '$1' if any in message)
-- mcode[3] = 'parm2' (string to replace '$2' if any in message)
-- mcode[4] = 'parm3' (string to replace '$3' if any in message)
local msg
if type(mcode) == 'table' then
if mcode[1] == 'cvt_no_output' then
-- Some errors should cause convert to output an empty string,
-- for example, for an optional field in an infobox.
return ''
end
msg = text_code.all_messages[mcode[1]]
end
parms.have_problem = true
local function subparm(fmt, ...)
local rep = {}
for i, v in ipairs({...}) do
rep['$' .. i] = v
end
return (fmt:gsub('$%d+', rep))
end
if msg then
local parts = {}
local regex, replace = msg.regex, msg.replace
for i = 1, 3 do
local limit = 40
local s = mcode[i + 1]
if s then
if regex and replace then
s = s:gsub(regex, replace)
limit = nil -- allow long "should be" messages
end
-- Escape user input so it does not break the message.
-- To avoid tags (like {{convert|1<math>23</math>|m}}) breaking
-- the mouseover title, any strip marker starting with char(127) is
-- replaced with '...' (text not needing i18n).
local append
local pos = s:find(string.char(127), 1, true)
if pos then
append = '...'
s = s:sub(1, pos - 1)
end
if limit and ulen(s) > limit then
s = usub(s, 1, limit)
append = '...'
end
s = mw.text.nowiki(s) .. (append or '')
else
s = '?'
end
parts['$' .. i] = s
end
local function ispreview()
-- Return true if a prominent message should be shown.
if parms.test == 'preview' or parms.test == 'nopreview' then
-- For testing, can preview a real message or simulate a preview
-- when running automated tests.
return parms.test == 'preview'
end
local success, revid = pcall(function ()
return (parms.frame):preprocess('{{REVISIONID}}') end)
return success and (revid == '')
end
local want_warning = is_warning and
not config.warnings and -- show unobtrusive warnings if config.warnings not configured
not msg.nowarn -- but use msg settings, not standard warning, if specified
local title = string.gsub(msg[1] or 'Missing message', '$%d+', parts)
local text = want_warning and '*' or msg[2] or 'Missing message'
local cat = wanted_category(msg[3], mcode[2], want_warning)
local anchor = msg[4] or ''
local fmtkey = ispreview() and 'cvt_format_preview' or
(want_warning and 'cvt_format2' or msg.format or 'cvt_format')
local fmt = text_code.all_messages[fmtkey] or 'convert: bug'
return subparm(fmt, title:gsub('"', '"'), text, cat, anchor)
end
return 'Convert internal error: unknown message'
end
function add_warning(parms, level, key, text1, text2) -- for forward declaration above
-- If enabled, add a warning that will be displayed after the convert result.
-- A higher level is more verbose: more kinds of warnings are displayed.
-- To reduce output noise, only the first warning is displayed.
if level <= (tonumber(config.warnings) or 1) then
if parms.warnings == nil then
parms.warnings = message(parms, { key, text1, text2 }, true)
end
end
end
local function spell_number(parms, inout, number, numerator, denominator)
-- Return result of spelling (number, numerator, denominator), or
-- return nil if spelling is not available or not supported for given text.
-- Examples (each value must be a string or nil):
-- number numerator denominator output
-- ------ --------- ----------- -------------------
-- "1.23" nil nil one point two three
-- "1" "2" "3" one and two thirds
-- nil "2" "3" two thirds
if not speller then
local function get_speller(module)
return require(module).spell_number
end
local success
success, speller = pcall(get_speller, spell_module)
if not success or type(speller) ~= 'function' then
add_warning(parms, 1, 'cvt_no_spell', 'spell')
return nil
end
end
local case
if parms.spell_upper == inout then
case = true
parms.spell_upper = nil -- only uppercase first word in a multiple unit
end
local sp = not parms.opt_sp_us
local adj = parms.opt_adjectival
return speller(number, numerator, denominator, case, sp, adj)
end
------------------------------------------------------------------------
-- BEGIN: Code required only for built-in units.
-- LATER: If need much more code, move to another module to simplify this module.
local function speed_of_sound(altitude)
-- This is for the Mach built-in unit of speed.
-- Return speed of sound in metres per second at given altitude in feet.
-- If no altitude given, use default (zero altitude = sea level).
-- Table gives speed of sound in miles per hour at various altitudes:
-- altitude = -17,499 to 402,499 feet
-- mach_table[a + 4] = s where
-- a = (altitude / 5000) rounded to nearest integer (-3 to 80)
-- s = speed of sound (mph) at that altitude
-- LATER: Should calculate result from an interpolation between the next
-- lower and higher altitudes in table, rather than rounding to nearest.
-- From: http://www.aerospaceweb.org/question/atmosphere/q0112.shtml
local mach_table = { -- a =
799.5, 787.0, 774.2, 761.207051, -- -3 to 0
748.0, 734.6, 721.0, 707.0, 692.8, 678.3, 663.5, 660.1, 660.1, 660.1, -- 1 to 10
660.1, 660.1, 660.1, 662.0, 664.3, 666.5, 668.9, 671.1, 673.4, 675.6, -- 11 to 20
677.9, 683.7, 689.9, 696.0, 702.1, 708.1, 714.0, 719.9, 725.8, 731.6, -- 21 to 30
737.3, 737.7, 737.7, 736.2, 730.5, 724.6, 718.8, 712.9, 707.0, 701.0, -- 31 to 40
695.0, 688.9, 682.8, 676.6, 670.4, 664.1, 657.8, 652.9, 648.3, 643.7, -- 41 to 50
639.1, 634.4, 629.6, 624.8, 620.0, 615.2, 613.2, 613.2, 613.2, 613.5, -- 51 to 60
614.4, 615.3, 616.7, 619.8, 623.4, 629.7, 635.0, 641.1, 650.6, 660.0, -- 61 to 70
672.5, 674.3, 676.1, 677.9, 679.7, 681.5, 683.3, 685.1, 686.8, 688.6, -- 71 to 80
}
altitude = altitude or 0
local a = (altitude < 0) and -altitude or altitude
a = floor(a / 5000 + 0.5)
if altitude < 0 then
a = -a
end
if a < -3 then
a = -3
elseif a > 80 then
a = 80
end
return mach_table[a + 4] * 0.44704 -- mph converted to m/s
end
-- END: Code required only for built-in units.
------------------------------------------------------------------------
local function add_style(parms, class)
-- Add selected template style to parms if not already present.
parms.templatestyles = parms.templatestyles or {}
if not parms.templatestyles[class] then
parms.templatestyles[class] = parms.frame:extensionTag({
name = 'templatestyles', args = { src = text_code.titles[class] }
})
end
end
local function get_styles(parms)
-- Return string of required template styles, empty if none.
if parms.templatestyles then
local t = {}
for _, v in pairs(parms.templatestyles) do
table.insert(t, v)
end
return table.concat(t)
end
return ''
end
local function get_range(word)
-- Return a range (string or table) corresponding to word (like "to"),
-- or return nil if not a range word.
local ranges = text_code.ranges
return ranges.types[word] or ranges.types[ranges.aliases[word]]
end
local function check_mismatch(unit1, unit2)
-- If unit1 cannot be converted to unit2, return an error message table.
-- This allows conversion between units of the same type, and between
-- Nm (normally torque) and ftlb (energy), as in gun-related articles.
-- This works because Nm is the base unit (scale = 1) for both the
-- primary type (torque), and the alternate type (energy, where Nm = J).
-- A match occurs if the primary types are the same, or if unit1 matches
-- the alternate type of unit2, and vice versa. That provides a whitelist
-- of which conversions are permitted between normally incompatible types.
if unit1.utype == unit2.utype or
(unit1.utype == unit2.alttype and unit1.alttype == unit2.utype) then
return nil
end
return { 'cvt_mismatch', unit1.utype, unit2.utype }
end
local function override_from(out_table, in_table, fields)
-- Copy the specified fields from in_table to out_table, but do not
-- copy nil fields (keep any corresponding field in out_table).
for _, field in ipairs(fields) do
if in_table[field] then
out_table[field] = in_table[field]
end
end
end
local function shallow_copy(t)
-- Return a shallow copy of table t.
-- Do not need the features and overhead of the Scribunto mw.clone().
local result = {}
for k, v in pairs(t) do
result[k] = v
end
return result
end
local unit_mt = {
-- Metatable to get missing values for a unit that does not accept SI prefixes.
-- Warning: The boolean value 'false' is returned for any missing field
-- so __index is not called twice for the same field in a given unit.
__index = function (self, key)
local value
if key == 'name1' or key == 'sym_us' then
value = self.symbol
elseif key == 'name2' then
value = self.name1 .. plural_suffix
elseif key == 'name1_us' then
value = self.name1
if not rawget(self, 'name2_us') then
-- If name1_us is 'foot', do not make name2_us by appending plural_suffix.
self.name2_us = self.name2
end
elseif key == 'name2_us' then
local raw1_us = rawget(self, 'name1_us')
if raw1_us then
value = raw1_us .. plural_suffix
else
value = self.name2
end
elseif key == 'link' then
value = self.name1
else
value = false
end
rawset(self, key, value)
return value
end
}
local function prefixed_name(unit, name, index)
-- Return unit name with SI prefix inserted at correct position.
-- index = 1 (name1), 2 (name2), 3 (name1_us), 4 (name2_us).
-- The position is a byte (not character) index, so use Lua's sub().
local pos = rawget(unit, 'prefix_position')
if type(pos) == 'string' then
pos = tonumber(split(pos, ',')[index])
end
if pos then
return name:sub(1, pos - 1) .. unit.si_name .. name:sub(pos)
end
return unit.si_name .. name
end
local unit_prefixed_mt = {
-- Metatable to get missing values for a unit that accepts SI prefixes.
-- Before use, fields si_name, si_prefix must be defined.
-- The unit must define _symbol, _name1 and
-- may define _sym_us, _name1_us, _name2_us
-- (_sym_us, _name2_us may be defined for a language using sp=us
-- to refer to a variant unrelated to U.S. units).
__index = function (self, key)
local value
if key == 'symbol' then
value = self.si_prefix .. self._symbol
if value == 'l' then value = 'L' end
elseif key == 'sym_us' then
value = rawget(self, '_sym_us')
if value then
value = self.si_prefix .. value
else
value = self.symbol
end
elseif key == 'name1' then
value = prefixed_name(self, self._name1, 1)
elseif key == 'name2' then
value = rawget(self, '_name2')
if value then
value = prefixed_name(self, value, 2)
else
value = self.name1 .. plural_suffix
end
elseif key == 'name1_us' then
value = rawget(self, '_name1_us')
if value then
value = prefixed_name(self, value, 3)
else
value = self.name1
end
elseif key == 'name2_us' then
value = rawget(self, '_name2_us')
if value then
value = prefixed_name(self, value, 4)
elseif rawget(self, '_name1_us') then
value = self.name1_us .. plural_suffix
else
value = self.name2
end
elseif key == 'link' then
value = self.name1
else
value = false
end
rawset(self, key, value)
return value
end
}
local unit_per_mt = {
-- Metatable to get values for a per unit of form "x/y".
-- This is never called to determine a unit name or link because per units
-- are handled as a special case.
-- Similarly, the default output is handled elsewhere, and for a symbol
-- this is only called from get_default() for default_exceptions.
__index = function (self, key)
local value
if key == 'symbol' then
local per = self.per
local unit1, unit2 = per[1], per[2]
if unit1 then
value = unit1[key] .. '/' .. unit2[key]
else
value = '/' .. unit2[key]
end
elseif key == 'sym_us' then
value = self.symbol
elseif key == 'scale' then
local per = self.per
local unit1, unit2 = per[1], per[2]
value = (unit1 and unit1.scale or 1) * self.scalemultiplier / unit2.scale
else
value = false
end
rawset(self, key, value)
return value
end
}
local function make_per(unitcode, unit_table, ulookup)
-- Return true, t where t is a per unit with unit codes expanded to unit tables,
-- or return false, t where t is an error message table.
local result = {
unitcode = unitcode,
utype = unit_table.utype,
per = {}
}
override_from(result, unit_table, { 'invert', 'iscomplex', 'default', 'link', 'symbol', 'symlink' })
result.symbol_raw = (result.symbol or false) -- to distinguish between a defined exception and a metatable calculation
local prefix
for i, v in ipairs(unit_table.per) do
if i == 1 and v == '' then
-- First unit symbol can be empty; that gives a nil first unit table.
elseif i == 1 and text_code.currency[v] then
prefix = currency_text or v
else
local success, t = ulookup(v)
if not success then return false, t end
result.per[i] = t
end
end
local multiplier = unit_table.multiplier
if not result.utype then
-- Creating an automatic per unit.
local unit1 = result.per[1]
local utype = (unit1 and unit1.utype or prefix or '') .. '/' .. result.per[2].utype
local t = data_code.per_unit_fixups[utype]
if t then
if type(t) == 'table' then
utype = t.utype or utype
result.link = result.link or t.link
multiplier = multiplier or t.multiplier
else
utype = t
end
end
result.utype = utype
end
result.scalemultiplier = multiplier or 1
result.vprefix = prefix or false -- set to non-nil to avoid calling __index
return true, setmetatable(result, unit_per_mt)
end
local function lookup(parms, unitcode, what, utable, fails, depth)
-- Return true, t where t is a copy of the unit's converter table,
-- or return false, t where t is an error message table.
-- Parameter 'what' determines whether combination units are accepted:
-- 'no_combination' : single unit only
-- 'any_combination' : single unit or combination or output multiple
-- 'only_multiple' : single unit or output multiple only
-- Parameter unitcode is a symbol (like 'g'), with an optional SI prefix (like 'kg').
-- If, for example, 'kg' is in this table, that entry is used;
-- otherwise the prefix ('k') is applied to the base unit ('g').
-- If unitcode is a known combination code (and if allowed by what),
-- a table of output multiple unit tables is included in the result.
-- For compatibility with the old template, an underscore in a unitcode is
-- replaced with a space so usage like {{convert|350|board_feet}} works.
-- Wikignomes may also put two spaces or " " in combinations, so
-- replace underscore, " ", and multiple spaces with a single space.
utable = utable or parms.unittable or all_units
fails = fails or {}
depth = depth and depth + 1 or 1
if depth > 9 then
-- There are ways to mistakenly define units which result in infinite
-- recursion when lookup() is called. That gives a long delay and very
-- confusing error messages, so the depth parameter is used as a guard.
return false, { 'cvt_lookup', unitcode }
end
if unitcode == nil or unitcode == '' then
return false, { 'cvt_no_unit' }
end
unitcode = unitcode:gsub('_', ' '):gsub(' ', ' '):gsub(' +', ' ')
local function call_make_per(t)
return make_per(unitcode, t,
function (ucode) return lookup(parms, ucode, 'no_combination', utable, fails, depth) end
)
end
local t = utable[unitcode]
if t then
if t.shouldbe then
return false, { 'cvt_should_be', t.shouldbe }
end
if t.sp_us then
parms.opt_sp_us = true
end
local target = t.target -- nil, or unitcode is an alias for this target
if target then
local success, result = lookup(parms, target, what, utable, fails, depth)
if not success then return false, result end
override_from(result, t, { 'customary', 'default', 'link', 'symbol', 'symlink', 'usename' })
local multiplier = t.multiplier
if multiplier then
result.multiplier = tostring(multiplier)
result.scale = result.scale * multiplier
end
return true, result
end
if t.per then
return call_make_per(t)
end
local combo = t.combination -- nil or a table of unitcodes
if combo then
local multiple = t.multiple
if what == 'no_combination' or (what == 'only_multiple' and not multiple) then
return false, { 'cvt_bad_unit', unitcode }
end
-- Recursively create a combination table containing the
-- converter table of each unitcode.
local result = { utype = t.utype, multiple = multiple, combination = {} }
local cvt = result.combination
for i, v in ipairs(combo) do
local success, t = lookup(parms, v, multiple and 'no_combination' or 'only_multiple', utable, fails, depth)
if not success then return false, t end
cvt[i] = t
end
return true, result
end
local result = shallow_copy(t)
result.unitcode = unitcode
if result.prefixes then
result.si_name = ''
result.si_prefix = ''
return true, setmetatable(result, unit_prefixed_mt)
end
return true, setmetatable(result, unit_mt)
end
local SIprefixes = text_code.SIprefixes
for plen = SIprefixes[1] or 2, 1, -1 do
-- Look for an SI prefix; should never occur with an alias.
-- Check for longer prefix first ('dam' is decametre).
-- SIprefixes[1] = prefix maximum #characters (as seen by mw.ustring.sub).
local prefix = usub(unitcode, 1, plen)
local si = SIprefixes[prefix]
if si then
local t = utable[usub(unitcode, plen+1)]
if t and t.prefixes then
local result = shallow_copy(t)
result.unitcode = unitcode
result.si_name = parms.opt_sp_us and si.name_us or si.name
result.si_prefix = si.prefix or prefix
result.scale = t.scale * 10 ^ (si.exponent * t.prefixes)
return true, setmetatable(result, unit_prefixed_mt)
end
end
end
-- Accept user-defined combinations like "acre+m2+ha" or "acre m2 ha" for output.
-- If '+' is used, each unit code can include a space, and any error is fatal.
-- If ' ' is used and if each space-separated word is a unit code, it is a combo,
-- but errors are not fatal so the unit code can be looked up as an extra unit.
local err_is_fatal
local combo = collection()
if unitcode:find('+', 1, true) then
err_is_fatal = true
for item in (unitcode .. '+'):gmatch('%s*(.-)%s*%+') do
if item ~= '' then
combo:add(item)
end
end
elseif unitcode:find('%s') then
for item in unitcode:gmatch('%S+') do
combo:add(item)
end
end
if combo.n > 1 then
local function lookup_combo()
if what == 'no_combination' or what == 'only_multiple' then
return false, { 'cvt_bad_unit', unitcode }
end
local result = { combination = {} }
local cvt = result.combination
for i, v in ipairs(combo) do
local success, t = lookup(parms, v, 'only_multiple', utable, fails, depth)
if not success then return false, t end
if i == 1 then
result.utype = t.utype
else
local mismatch = check_mismatch(result, t)
if mismatch then
return false, mismatch
end
end
cvt[i] = t
end
return true, result
end
local success, result = lookup_combo()
if success or err_is_fatal then
return success, result
end
end
-- Accept any unit with an engineering notation prefix like "e6cuft"
-- (million cubic feet), but not chained prefixes like "e3e6cuft",
-- and not if the unit is a combination or multiple,
-- and not if the unit has an offset or is a built-in.
-- Only en digits are accepted.
local e, exponent, baseunit = unitcode:match('^([Ee])(%d+)(.*)')
if exponent then
local engscale = text_code.eng_scales[exponent]
if engscale then
local success, result = lookup(parms, baseunit, 'no_combination', utable, fails, depth)
if success and not (result.offset or result.builtin or result.engscale) then
if e == 'E' then
result.this_number_word = true
unitcode = 'e' .. unitcode:sub(2)
end
result.unitcode = unitcode -- 'e6cuft' not 'cuft'
result.defkey = unitcode -- key to lookup default exception
result.engscale = engscale
result.scale = result.scale * 10 ^ tonumber(exponent)
return true, result
end
end
end
-- Look for x/y; split on right-most slash to get scale correct (x/y/z is x/y per z).
local top, bottom = unitcode:match('^(.-)/([^/]+)$')
if top and not unitcode:find('e%d') then
-- If valid, create an automatic per unit for an "x/y" unit code.
-- The unitcode must not include extraneous spaces.
-- Engineering notation (apart from at start and which has been stripped before here),
-- is not supported so do not make a per unit if find text like 'e3' in unitcode.
local success, result = call_make_per({ per = {top, bottom} })
if success then
return true, result
end
end
if not parms.opt_ignore_error and not get_range(unitcode) then
-- Want the "what links here" list for the extra_module to show only cases
-- where an extra unit is used, so do not require it if invoked from {{val}}
-- or if looking up a range word which cannot be a unit.
if not extra_units then
local success, extra = pcall(function () return require(extra_module).extra_units end)
if success and type(extra) == 'table' then
extra_units = extra
end
end
if extra_units then
-- A unit in one data table might refer to a unit in the other table, so
-- switch between them, relying on fails or depth to terminate loops.
if not fails[unitcode] then
fails[unitcode] = true
local other = (utable == all_units) and extra_units or all_units
local success, result = lookup(parms, unitcode, what, other, fails, depth)
if success then
return true, result
end
end
end
end
if to_en_table then
-- At fawiki it is common to translate all digits so a unit like "km2" becomes "km۲".
local en_code = ustring.gsub(unitcode, '%d', to_en_table)
if en_code ~= unitcode then
return lookup(parms, en_code, what, utable, fails, depth)
end
end
return false, { 'cvt_unknown', unitcode }
end
local function valid_number(num)
-- Return true if num is a valid number.
-- In Scribunto (different from some standard Lua), when expressed as a string,
-- overflow or other problems are indicated with text like "inf" or "nan"
-- which are regarded as invalid here (each contains "n").
if type(num) == 'number' and tostring(num):find('n', 1, true) == nil then
return true
end
end
local function hyphenated(name, parts)
-- Return a hyphenated form of given name (for adjectival usage).
-- The name may be linked and the target of the link must not be changed.
-- Hypothetical examples:
-- [[long ton|ton]] → [[long ton|ton]] (no change)
-- [[tonne|long ton]] → [[tonne|long-ton]]
-- [[metric ton|long ton]] → [[metric ton|long-ton]]
-- [[long ton]] → [[long ton|long-ton]]
-- Input can also have multiple links in a single name like:
-- [[United States customary units|U.S.]] [[US gallon|gallon]]
-- [[mile]]s per [[United States customary units|U.S.]] [[quart]]
-- [[long ton]]s per [[short ton]]
-- Assume that links cannot be nested (never like "[[abc[[def]]ghi]]").
-- This uses a simple and efficient procedure that works for most cases.
-- Some units (if used) would require more, and can later think about
-- adding a method to handle exceptions.
-- The procedure is to replace each space with a hyphen, but
-- not a space after ')' [for "(pre-1954 US) nautical mile"], and
-- not spaces immediately before '(' or in '(...)' [for cases like
-- "British thermal unit (ISO)" and "Calorie (International Steam Table)"].
if name:find(' ', 1, true) then
if parts then
local pos
if name:sub(1, 1) == '(' then
pos = name:find(')', 1, true)
if pos then
return name:sub(1, pos+1) .. name:sub(pos+2):gsub(' ', '-')
end
elseif name:sub(-1) == ')' then
pos = name:find('(', 1, true)
if pos then
return name:sub(1, pos-2):gsub(' ', '-') .. name:sub(pos-1)
end
end
return name:gsub(' ', '-')
end
parts = collection()
for before, item, after in name:gmatch('([^[]*)(%[%[[^[]*%]%])([^[]*)') do
if item:find(' ', 1, true) then
local prefix
local plen = item:find('|', 1, true)
if plen then
prefix = item:sub(1, plen)
item = item:sub(plen + 1, -3)
else
prefix = item:sub(1, -3) .. '|'
item = item:sub(3, -3)
end
item = prefix .. hyphenated(item, parts) .. ']]'
end
parts:add(before:gsub(' ', '-') .. item .. after:gsub(' ', '-'))
end
if parts.n == 0 then
-- No link like "[[...]]" was found in the original name.
parts:add(hyphenated(name, parts))
end
return table.concat(parts)
end
return name
end
local function hyphenated_maybe(parms, want_name, sep, id, inout)
-- Return s, f where
-- s = id, possibly modified
-- f = true if hyphenated
-- Possible modifications: hyphenate; prepend '-'; append mid text.
if id == nil or id == '' then
return ''
end
local mid = (inout == (parms.opt_flip and 'out' or 'in')) and parms.mid or ''
if want_name then
if parms.opt_adjectival then
return '-' .. hyphenated(id) .. mid, true
end
if parms.opt_add_s and id:sub(-1) ~= 's' then
id = id .. 's' -- for nowiki
end
end
return sep .. id .. mid
end
local function use_minus(text)
-- Return text with Unicode minus instead of '-', if present.
if text:sub(1, 1) == '-' then
return MINUS .. text:sub(2)
end
return text
end
local function digit_groups(parms, text, method)
-- Return a numbered table of groups of digits (left-to-right, in local language).
-- Parameter method is a number or nil:
-- 3 for 3-digit grouping (default), or
-- 2 for 3-then-2 grouping (only for digits before decimal mark).
local len_right
local len_left = text:find('.', 1, true)
if len_left then
len_right = #text - len_left
len_left = len_left - 1
else
len_left = #text
end
local twos = method == 2 and len_left > 5
local groups = collection()
local run = len_left
local n
if run < 4 or (run == 4 and parms.opt_comma5) then
if parms.opt_gaps then
n = run
else
n = #text
end
elseif twos then
n = run % 2 == 0 and 1 or 2
else
n = run % 3 == 0 and 3 or run % 3
end
while run > 0 do
groups:add(n)
run = run - n
n = (twos and run > 3) and 2 or 3
end
if len_right then
if groups.n == 0 then
groups:add(0)
end
if parms.opt_gaps and len_right > 3 then
local want4 = not parms.opt_gaps3 -- true gives no gap before trailing single digit
local isfirst = true
run = len_right
while run > 0 do
n = (want4 and run == 4) and 4 or (run > 3 and 3 or run)
if isfirst then
isfirst = false
groups[groups.n] = groups[groups.n] + 1 + n
else
groups:add(n)
end
run = run - n
end
else
groups[groups.n] = groups[groups.n] + 1 + len_right
end
end
local pos = 1
for i, length in ipairs(groups) do
groups[i] = from_en(text:sub(pos, pos + length - 1))
pos = pos + length
end
return groups
end
function with_separator(parms, text) -- for forward declaration above
-- Input text is a number in en digits with optional '.' decimal mark.
-- Return an equivalent, formatted for display:
-- with a custom decimal mark instead of '.', if wanted
-- with thousand separators inserted, if wanted
-- digits in local language
-- The given text is like '123' or '123.' or '12345.6789'.
-- The text has no sign (caller inserts that later, if necessary).
-- When using gaps, they are inserted before and after the decimal mark.
-- Separators are inserted only before the decimal mark.
-- A trailing dot (as in '123.') is removed because their use appears to
-- be accidental, and such a number should be shown as '123' or '123.0'.
-- It is useful for convert to suppress the dot so, for example, '4000.'
-- is a simple way of indicating that all the digits are significant.
if text:sub(-1) == '.' then
text = text:sub(1, -2)
end
if #text < 4 or parms.opt_nocomma or numsep == '' then
return from_en(text)
end
local groups = digit_groups(parms, text, group_method)
if parms.opt_gaps then
if groups.n <= 1 then
return groups[1] or ''
end
local nowrap = '<span style="white-space: nowrap">'
local gap = '<span style="margin-left: 0.25em">'
local close = '</span>'
return nowrap .. groups[1] .. gap .. table.concat(groups, close .. gap, 2, groups.n) .. close .. close
end
return table.concat(groups, numsep)
end
-- An input value like 1.23e12 is displayed using scientific notation (1.23×10¹²).
-- That also makes the output use scientific notation, except for small values.
-- In addition, very small or very large output values use scientific notation.
-- Use format(fmtpower, significand, '10', exponent) where each argument is a string.
local fmtpower = '%s<span style="margin:0 .15em 0 .25em">×</span>%s<sup>%s</sup>'
local function with_exponent(parms, show, exponent)
-- Return wikitext to display the implied value in scientific notation.
-- Input uses en digits; output uses digits in local language.
return format(fmtpower, with_separator(parms, show), from_en('10'), use_minus(from_en(tostring(exponent))))
end
local function make_sigfig(value, sigfig)
-- Return show, exponent that are equivalent to the result of
-- converting the number 'value' (where value >= 0) to a string,
-- rounded to 'sigfig' significant figures.
-- The returned items are:
-- show: a string of digits; no sign and no dot;
-- there is an implied dot before show.
-- exponent: a number (an integer) to shift the implied dot.
-- Resulting value = tonumber('.' .. show) * 10^exponent.
-- Examples:
-- make_sigfig(23.456, 3) returns '235', 2 (.235 * 10^2).
-- make_sigfig(0.0023456, 3) returns '235', -2 (.235 * 10^-2).
-- make_sigfig(0, 3) returns '000', 1 (.000 * 10^1).
if sigfig <= 0 then
sigfig = 1
elseif sigfig > maxsigfig then
sigfig = maxsigfig
end
if value == 0 then
return string.rep('0', sigfig), 1
end
local exp, fracpart = math.modf(log10(value))
if fracpart >= 0 then
fracpart = fracpart - 1
exp = exp + 1
end
local digits = format('%.0f', 10^(fracpart + sigfig))
if #digits > sigfig then
-- Overflow (for sigfig=3: like 0.9999 rounding to "1000"; need "100").
digits = digits:sub(1, sigfig)
exp = exp + 1
end
assert(#digits == sigfig, 'Bug: rounded number has wrong length')
return digits, exp
end
-- Fraction output format.
local fracfmt = {
{ -- Like {{frac}} (fraction slash).
'<span class="frac">{SIGN}<span class="num">{NUM}</span>⁄<span class="den">{DEN}</span></span>', -- 1/2
'<span class="frac">{SIGN}{WHOLE}<span class="sr-only">+</span><span class="num">{NUM}</span>⁄<span class="den">{DEN}</span></span>', -- 1+2/3
style = 'frac',
},
{ -- Like {{sfrac}} (stacked fraction, that is, horizontal bar).
'<span class="sfrac tion">{SIGN}<span class="num">{NUM}</span><span class="sr-only">/</span><span class="den">{DEN}</span></span>', -- 1//2
'<span class="sfrac">{SIGN}{WHOLE}<span class="sr-only">+</span><span class="tion"><span class="num">{NUM}</span><span class="sr-only">/</span><span class="den">{DEN}</span></span></span>', -- 1+2//3
style = 'sfrac',
},
}
local function format_fraction(parms, inout, negative, wholestr, numstr, denstr, do_spell, style)
-- Return wikitext for a fraction, possibly spelled.
-- Inputs use en digits and have no sign; output uses digits in local language.
local wikitext
if not style then
style = parms.opt_fraction_horizontal and 2 or 1
end
if wholestr == '' then
wholestr = nil
end
local substitute = {
SIGN = negative and MINUS or '',
WHOLE = wholestr and with_separator(parms, wholestr),
NUM = from_en(numstr),
DEN = from_en(denstr),
}
wikitext = fracfmt[style][wholestr and 2 or 1]:gsub('{(%u+)}', substitute)
if do_spell then
if negative then
if wholestr then
wholestr = '-' .. wholestr
else
numstr = '-' .. numstr
end
end
local s = spell_number(parms, inout, wholestr, numstr, denstr)
if s then
return s
end
end
add_style(parms, fracfmt[style].style)
return wikitext
end
local function format_number(parms, show, exponent, isnegative)
-- Parameter show is a string or a table containing strings.
-- Each string is a formatted number in en digits and optional '.' decimal mark.
-- A table represents a fraction: integer, numerator, denominator;
-- if a table is given, exponent must be nil.
-- Return t where t is a table with fields:
-- show = wikitext formatted to display implied value
-- (digits in local language)
-- is_scientific = true if show uses scientific notation
-- clean = unformatted show (possibly adjusted and with inserted '.')
-- (en digits)
-- sign = '' or MINUS
-- exponent = exponent (possibly adjusted)
-- The clean and exponent fields can be used to calculate the
-- rounded absolute value, if needed.
--
-- The value implied by the arguments is found from:
-- exponent is nil; and
-- show is a string of digits (no sign), with an optional dot;
-- show = '123.4' is value 123.4, '1234' is value 1234.0;
-- or:
-- exponent is an integer indicating where dot should be;
-- show is a string of digits (no sign and no dot);
-- there is an implied dot before show;
-- show does not start with '0';
-- show = '1234', exponent = 3 is value 0.1234*10^3 = 123.4.
--
-- The formatted result:
-- * Is for an output value and is spelled if wanted and possible.
-- * Includes a Unicode minus if isnegative and not spelled.
-- * Uses a custom decimal mark, if wanted.
-- * Has digits grouped where necessary, if wanted.
-- * Uses scientific notation if requested, or for very small or large values
-- (which forces result to not be spelled).
-- * Has no more than maxsigfig significant digits
-- (same as old template and {{#expr}}).
local xhi, xlo -- these control when scientific notation (exponent) is used
if parms.opt_scientific then
xhi, xlo = 4, 2 -- default for output if input uses e-notation
elseif parms.opt_scientific_always then
xhi, xlo = 0, 0 -- always use scientific notation (experimental)
else
xhi, xlo = 10, 4 -- default
end
local sign = isnegative and MINUS or ''
local maxlen = maxsigfig
local tfrac
if type(show) == 'table' then
tfrac = show
show = tfrac.wholestr
assert(exponent == nil, 'Bug: exponent given with fraction')
end
if not tfrac and not exponent then
local integer, dot, decimals = show:match('^(%d*)(%.?)(.*)')
if integer == '0' or integer == '' then
local zeros, figs = decimals:match('^(0*)([^0]?.*)')
if #figs == 0 then
if #zeros > maxlen then
show = '0.' .. zeros:sub(1, maxlen)
end
elseif #zeros >= xlo then
show = figs
exponent = -#zeros
elseif #figs > maxlen then
show = '0.' .. zeros .. figs:sub(1, maxlen)
end
elseif #integer >= xhi then
show = integer .. decimals
exponent = #integer
else
maxlen = maxlen + #dot
if #show > maxlen then
show = show:sub(1, maxlen)
end
end
end
if exponent then
local function zeros(n)
return string.rep('0', n)
end
if #show > maxlen then
show = show:sub(1, maxlen)
end
if exponent > xhi or exponent <= -xlo or (exponent == xhi and show ~= '1' .. zeros(xhi - 1)) then
-- When xhi, xlo = 10, 4 (the default), scientific notation is used if the
-- rounded value satisfies: value >= 1e9 or value < 1e-4 (1e9 = 0.1e10),
-- except if show is '1000000000' (1e9), for example:
-- {{convert|1000000000|m|m|sigfig=10}} → 1,000,000,000 metres (1,000,000,000 m)
local significand
if #show > 1 then
significand = show:sub(1, 1) .. '.' .. show:sub(2)
else
significand = show
end
return {
clean = '.' .. show,
exponent = exponent,
sign = sign,
show = sign .. with_exponent(parms, significand, exponent-1),
is_scientific = true,
}
end
if exponent >= #show then
show = show .. zeros(exponent - #show) -- result has no dot
elseif exponent <= 0 then
show = '0.' .. zeros(-exponent) .. show
else
show = show:sub(1, exponent) .. '.' .. show:sub(exponent+1)
end
end
local formatted_show
if tfrac then
show = tostring(tfrac.value) -- to set clean in returned table
formatted_show = format_fraction(parms, 'out', isnegative, tfrac.wholestr, tfrac.numstr, tfrac.denstr, parms.opt_spell_out)
else
if isnegative and show:match('^0.?0*$') then
sign = '' -- don't show minus if result is negative but rounds to zero
end
formatted_show = sign .. with_separator(parms, show)
if parms.opt_spell_out then
formatted_show = spell_number(parms, 'out', sign .. show) or formatted_show
end
end
return {
clean = show,
sign = sign,
show = formatted_show,
is_scientific = false, -- to avoid calling __index
}
end
local function extract_fraction(parms, text, negative)
-- If text represents a fraction, return
-- value, altvalue, show, denominator
-- where
-- value is a number (value of the fraction in argument text)
-- altvalue is an alternate interpretation of any fraction for the hands
-- unit where "12.1+3/4" means 12 hands 1.75 inches
-- show is a string (formatted text for display of an input value,
-- and is spelled if wanted and possible)
-- denominator is value of the denominator in the fraction
-- Otherwise, return nil.
-- Input uses en digits and '.' decimal mark (input has been translated).
-- Output uses digits in local language and local decimal mark, if any.
------------------------------------------------------------------------
-- Originally this function accepted x+y/z where x, y, z were any valid
-- numbers, possibly with a sign. For example '1.23e+2+1.2/2.4' = 123.5,
-- and '2-3/8' = 1.625. However, such usages were found to be errors or
-- misunderstandings, so since August 2014 the following restrictions apply:
-- x (if present) is an integer or has a single digit after decimal mark
-- y and z are unsigned integers
-- e-notation is not accepted
-- The overall number can start with '+' or '-' (so '12+3/4' and '+12+3/4'
-- and '-12-3/4' are valid).
-- Any leading negative sign is removed by the caller, so only inputs
-- like the following are accepted here (may have whitespace):
-- negative = false false true (there was a leading '-')
-- text = '2/3' '+2/3' '2/3'
-- text = '1+2/3' '+1+2/3' '1-2/3'
-- text = '12.3+1/2' '+12.3+1/2' '12.3-1/2'
-- Values like '12.3+1/2' are accepted, but are intended only for use
-- with the hands unit (not worth adding code to enforce that).
------------------------------------------------------------------------
local leading_plus, prefix, numstr, slashes, denstr =
text:match('^%s*(%+?)%s*(.-)%s*(%d+)%s*(/+)%s*(%d+)%s*$')
if not leading_plus then
-- Accept a single U+2044 fraction slash because that may be pasted.
leading_plus, prefix, numstr, denstr =
text:match('^%s*(%+?)%s*(.-)%s*(%d+)%s*⁄%s*(%d+)%s*$')
slashes = '/'
end
local numerator = tonumber(numstr)
local denominator = tonumber(denstr)
if numerator == nil or denominator == nil or (negative and leading_plus ~= '') then
return nil
end
local whole, wholestr
if prefix == '' then
wholestr = ''
whole = 0
else
-- Any prefix must be like '12+' or '12-' (whole number and fraction sign);
-- '12.3+' and '12.3-' are also accepted (single digit after decimal point)
-- because '12.3+1/2 hands' is valid (12 hands 3½ inches).
local num1, num2, frac_sign = prefix:match('^(%d+)(%.?%d?)%s*([+%-])$')
if num1 == nil then return nil end
if num2 == '' then -- num2 must be '' or like '.1' but not '.' or '.12'
wholestr = num1
else
if #num2 ~= 2 then return nil end
wholestr = num1 .. num2
end
if frac_sign ~= (negative and '-' or '+') then return nil end
whole = tonumber(wholestr)
if whole == nil then return nil end
end
local value = whole + numerator / denominator
if not valid_number(value) then return nil end
local altvalue = whole + numerator / (denominator * 10)
local style = #slashes -- kludge: 1 or 2 slashes can be used to select style
if style > 2 then style = 2 end
local wikitext = format_fraction(parms, 'in', negative, leading_plus .. wholestr, numstr, denstr, parms.opt_spell_in, style)
return value, altvalue, wikitext, denominator
end
local function extract_number(parms, text, another, no_fraction)
-- Return true, info if can extract a number from text,
-- where info is a table with the result,
-- or return false, t where t is an error message table.
-- Input can use en digits or digits in local language and can
-- have references at the end. Accepting references is intended
-- for use in infoboxes with a field for a value passed to convert.
-- Parameter another = true if the expected value is not the first.
-- Before processing, the input text is cleaned:
-- * Any thousand separators (valid or not) are removed.
-- * Any sign is replaced with '-' (if negative) or '' (otherwise).
-- That replaces Unicode minus with '-'.
-- If successful, the returned info table contains named fields:
-- value = a valid number
-- altvalue = a valid number, usually same as value but different
-- if fraction used (for hands unit)
-- singular = true if value is 1 or -1 (to use singular form of units)
-- clean = cleaned text with any separators and sign removed
-- (en digits and '.' decimal mark)
-- show = text formatted for output, possibly with ref strip markers
-- (digits in local language and custom decimal mark)
-- The resulting show:
-- * Is for an input value and is spelled if wanted and possible.
-- * Has a rounded value, if wanted.
-- * Has digits grouped where necessary, if wanted.
-- * If negative, a Unicode minus is used; otherwise the sign is
-- '+' (if the input text used '+'), or is '' (if no sign in input).
text = strip(text or '')
local reference
local pos = text:find('\127', 1, true)
if pos then
local before = text:sub(1, pos - 1)
local remainder = text:sub(pos)
local refs = {}
while #remainder > 0 do
local ref, spaces
ref, spaces, remainder = remainder:match('^(\127[^\127]*UNIQ[^\127]*%-ref[^\127]*\127)(%s*)(.*)')
if ref then
table.insert(refs, ref)
else
refs = {}
break
end
end
if #refs > 0 then
text = strip(before)
reference = table.concat(refs)
end
end
local clean = to_en(text, parms)
if clean == '' then
return false, { another and 'cvt_no_num2' or 'cvt_no_num' }
end
local isnegative, propersign = false, '' -- most common case
local singular, show, denominator
local value = tonumber(clean)
local altvalue
if value then
local sign = clean:sub(1, 1)
if sign == '+' or sign == '-' then
propersign = (sign == '+') and '+' or MINUS
clean = clean:sub(2)
end
if value < 0 then
isnegative = true
value = -value
end
else
local valstr
for _, prefix in ipairs({ '-', MINUS, '−' }) do
-- Including '-' sets isnegative in case input is a fraction like '-2-3/4'.
local plen = #prefix
if clean:sub(1, plen) == prefix then
valstr = clean:sub(plen + 1)
if valstr:match('^%s') then -- "- 1" is invalid but "-1 - 1/2" is ok
return false, { 'cvt_bad_num', text }
end
break
end
end
if valstr then
isnegative = true
propersign = MINUS
clean = valstr
value = tonumber(clean)
end
if value == nil then
if not no_fraction then
value, altvalue, show, denominator = extract_fraction(parms, clean, isnegative)
end
if value == nil then
return false, { 'cvt_bad_num', text }
end
if value <= 1 then
singular = true -- for example, "½ mile" or "one half mile" (singular unit)
end
end
end
if not valid_number(value) then -- for example, "1e310" may overflow
return false, { 'cvt_invalid_num' }
end
if show == nil then
-- clean is a non-empty string with no spaces, and does not represent a fraction,
-- and value = tonumber(clean) is a number >= 0.
-- If the input uses e-notation, show will be displayed using a power of ten, but
-- we use the number as given so it might not be normalized scientific notation.
-- The input value is spelled if specified so any e-notation is ignored;
-- that allows input like 2e6 to be spelled as "two million" which works
-- because the spell module converts '2e6' to '2000000' before spelling.
local function rounded(value, default, exponent)
local precision = parms.opt_ri
if precision then
local fmt = '%.' .. format('%d', precision) .. 'f'
local result = fmt:format(tonumber(value) + 2e-14) -- fudge for some common cases of bad rounding
if not exponent then
singular = (tonumber(result) == 1)
end
return result
end
return default
end
singular = (value == 1)
local scientific
local significand, exponent = clean:match('^([%d.]+)[Ee]([+%-]?%d+)')
if significand then
show = with_exponent(parms, rounded(significand, significand, exponent), exponent)
scientific = true
else
show = with_separator(parms, rounded(value, clean))
end
show = propersign .. show
if parms.opt_spell_in then
show = spell_number(parms, 'in', propersign .. rounded(value, clean)) or show
scientific = false
end
if scientific then
parms.opt_scientific = true
end
end
if isnegative and (value ~= 0) then
value = -value
altvalue = -(altvalue or value)
end
return true, {
value = value,
altvalue = altvalue or value,
singular = singular,
clean = clean,
show = show .. (reference or ''),
denominator = denominator,
}
end
local function get_number(text)
-- Return v, f where:
-- v = nil (text is not a number)
-- or
-- v = value of text (text is a number)
-- f = true if value is an integer
-- Input can use en digits or digits in local language or separators,
-- but no Unicode minus, and no fraction.
if text then
local number = tonumber(to_en(text))
if number then
local _, fracpart = math.modf(number)
return number, (fracpart == 0)
end
end
end
local function gcd(a, b)
-- Return the greatest common denominator for the given values,
-- which are known to be positive integers.
if a > b then
a, b = b, a
end
if a <= 0 then
return b
end
local r = b % a
if r <= 0 then
return a
end
if r == 1 then
return 1
end
return gcd(r, a)
end
local function fraction_table(value, denominator)
-- Return value as a string or a table:
-- * If result is a string, there is no fraction, and the result
-- is value formatted as a string of en digits.
-- * If result is a table, it represents a fraction with named fields:
-- wholestr, numstr, denstr (strings of en digits for integer, numerator, denominator).
-- The result is rounded to the nearest multiple of (1/denominator).
-- If the multiple is zero, no fraction is included.
-- No fraction is included if value is very large as the fraction would
-- be unhelpful, particularly if scientific notation is required.
-- Input value is a non-negative number.
-- Input denominator is a positive integer for the desired fraction.
if value <= 0 then
return '0'
end
if denominator <= 0 or value > 1e8 then
return format('%.2f', value)
end
local integer, decimals = math.modf(value)
local numerator = floor((decimals * denominator) +
0.5 + 2e-14) -- add fudge for some common cases of bad rounding
if numerator >= denominator then
integer = integer + 1
numerator = 0
end
local wholestr = tostring(integer)
if numerator > 0 then
local div = gcd(numerator, denominator)
if div > 1 then
numerator = numerator / div
denominator = denominator / div
end
return {
wholestr = (integer > 0) and wholestr or '',
numstr = tostring(numerator),
denstr = tostring(denominator),
value = value,
}
end
return wholestr
end
local function preunits(count, preunit1, preunit2)
-- If count is 1:
-- ignore preunit2
-- return p1
-- else:
-- preunit1 is used for preunit2 if the latter is empty
-- return p1, p2
-- where:
-- p1 is text to insert before the input unit
-- p2 is text to insert before the output unit
-- p1 or p2 may be nil to mean "no preunit"
-- Using '+' gives output like "5+ feet" (no space before, but space after).
local function withspace(text, wantboth)
-- Return text with space before and, if wantboth, after.
-- However, no space is added if there is a space or ' ' or '-'
-- at that position ('-' is for adjectival text).
-- There is also no space if text starts with '&'
-- (e.g. '°' would display a degree symbol with no preceding space).
local char = text:sub(1, 1)
if char == '&' then
return text -- an html entity can be used to specify the exact display
end
if not (char == ' ' or char == '-' or char == '+') then
text = ' ' .. text
end
if wantboth then
char = text:sub(-1, -1)
if not (char == ' ' or char == '-' or text:sub(-6, -1) == ' ') then
text = text .. ' '
end
end
return text
end
local PLUS = '+ '
preunit1 = preunit1 or ''
local trim1 = strip(preunit1)
if count == 1 then
if trim1 == '' then
return nil
end
if trim1 == '+' then
return PLUS
end
return withspace(preunit1, true)
end
preunit1 = withspace(preunit1)
preunit2 = preunit2 or ''
local trim2 = strip(preunit2)
if trim1 == '+' then
if trim2 == '' or trim2 == '+' then
return PLUS, PLUS
end
preunit1 = PLUS
end
if trim2 == '' then
if trim1 == '' then
return nil, nil
end
preunit2 = preunit1
elseif trim2 == '+' then
preunit2 = PLUS
elseif trim2 == ' ' then -- trick to make preunit2 empty
preunit2 = nil
else
preunit2 = withspace(preunit2)
end
return preunit1, preunit2
end
local function range_text(range, want_name, parms, before, after, inout, options)
-- Return before .. rtext .. after
-- where rtext is the text that separates two values in a range.
local rtext, adj_text, exception
options = options or {}
if type(range) == 'table' then
-- Table must specify range text for ('off' and 'on') or ('input' and 'output'),
-- and may specify range text for 'adj=on',
-- and may specify exception = true.
rtext = range[want_name and 'off' or 'on'] or
range[((inout == 'in') == (parms.opt_flip == true)) and 'output' or 'input']
adj_text = range['adj']
exception = range['exception']
else
rtext = range
end
if parms.opt_adjectival then
if want_name or (exception and parms.abbr_org == 'on') then
rtext = adj_text or rtext:gsub(' ', '-'):gsub(' ', '-')
end
end
if rtext == '–' and (options.spaced or after:sub(1, #MINUS) == MINUS) then
rtext = ' – '
end
return before .. rtext .. after
end
local function get_composite(parms, iparm, in_unit_table)
-- Look for a composite input unit. For example, {{convert|1|yd|2|ft|3|in}}
-- would result in a call to this function with
-- iparm = 3 (parms[iparm] = "2", just after the first unit)
-- in_unit_table = (unit table for "yd"; contains value 1 for number of yards)
-- Return true, iparm, unit where
-- iparm = index just after the composite units (7 in above example)
-- unit = composite unit table holding all input units,
-- or return true if no composite unit is present in parms,
-- or return false, t where t is an error message table.
local default, subinfo
local composite_units, count = { in_unit_table }, 1
local fixups = {}
local total = in_unit_table.valinfo[1].value
local subunit = in_unit_table
while subunit.subdivs do -- subdivs is nil or a table of allowed subdivisions
local subcode = strip(parms[iparm+1])
local subdiv = subunit.subdivs[subcode] or subunit.subdivs[(all_units[subcode] or {}).target]
if not subdiv then
break
end
local success
success, subunit = lookup(parms, subcode, 'no_combination')
if not success then return false, subunit end -- should never occur
success, subinfo = extract_number(parms, parms[iparm])
if not success then return false, subinfo end
iparm = iparm + 2
subunit.inout = 'in'
subunit.valinfo = { subinfo }
-- Recalculate total as a number of subdivisions.
-- subdiv[1] = number of subdivisions per previous unit (integer > 1).
total = total * subdiv[1] + subinfo.value
if not default then -- set by the first subdiv with a default defined
default = subdiv.default
end
count = count + 1
composite_units[count] = subunit
if subdiv.unit or subdiv.name then
fixups[count] = { unit = subdiv.unit, name = subdiv.name, valinfo = subunit.valinfo }
end
end
if count == 1 then
return true -- no error and no composite unit
end
for i, fixup in pairs(fixups) do
local unit = fixup.unit
local name = fixup.name
if not unit or (count > 2 and name) then
composite_units[i].fixed_name = name
else
local success, alternate = lookup(parms, unit, 'no_combination')
if not success then return false, alternate end -- should never occur
alternate.inout = 'in'
alternate.valinfo = fixup.valinfo
composite_units[i] = alternate
end
end
return true, iparm, {
utype = in_unit_table.utype,
scale = subunit.scale, -- scale of last (least significant) unit
valinfo = { { value = total, clean = subinfo.clean, denominator = subinfo.denominator } },
composite = composite_units,
default = default or in_unit_table.default
}
end
local function translate_parms(parms, kv_pairs)
-- Update fields in parms by translating each key:value in kv_pairs to terms
-- used by this module (may involve translating from local language to English).
-- Also, checks are performed which may display warnings, if enabled.
-- Return true if successful or return false, t where t is an error message table.
currency_text = nil -- local testing can hold module in memory; must clear globals
if kv_pairs.adj and kv_pairs.sing then
-- For enwiki (before translation), warn if attempt to use adj and sing
-- as the latter is a deprecated alias for the former.
if kv_pairs.adj ~= kv_pairs.sing and kv_pairs.sing ~= '' then
add_warning(parms, 1, 'cvt_unknown_option', 'sing=' .. kv_pairs.sing)
end
kv_pairs.sing = nil
end
kv_pairs.comma = kv_pairs.comma or config.comma -- for plwiki who want default comma=5
for loc_name, loc_value in pairs(kv_pairs) do
local en_name = text_code.en_option_name[loc_name]
if en_name then
local en_value = text_code.en_option_value[en_name]
if en_value == 'INTEGER' then -- altitude_ft, altitude_m, frac, sigfig
en_value = nil
if loc_value == '' then
add_warning(parms, 2, 'cvt_empty_option', loc_name)
else
local minimum
local number, is_integer = get_number(loc_value)
if en_name == 'sigfig' then
minimum = 1
elseif en_name == 'frac' then
minimum = 2
if number and number < 0 then
parms.opt_fraction_horizontal = true
number = -number
end
else
minimum = -1e6
end
if number and is_integer and number >= minimum then
en_value = number
else
local m
if en_name == 'frac' then
m = 'cvt_bad_frac'
elseif en_name == 'sigfig' then
m = 'cvt_bad_sigfig'
else
m = 'cvt_bad_altitude'
end
add_warning(parms, 1, m, loc_name .. '=' .. loc_value)
end
end
elseif en_value == 'TEXT' then -- $, input, qid, qual, stylein, styleout, tracking
en_value = loc_value ~= '' and loc_value or nil -- accept non-empty user text with no validation
if not en_value and (en_name == '$' or en_name == 'qid' or en_name == 'qual') then
add_warning(parms, 2, 'cvt_empty_option', loc_name)
elseif en_name == '$' then
-- Value should be a single character like "€" for the euro currency symbol, but anything is accepted.
currency_text = (loc_value == 'euro') and '€' or loc_value
elseif en_name == 'input' then
-- May have something like {{convert|input=}} (empty input) if source is an infobox
-- with optional fields. In that case, want to output nothing rather than an error.
parms.input_text = loc_value -- keep input because parms.input is nil if loc_value == ''
end
else
en_value = en_value[loc_value]
if en_value and en_value:sub(-1) == '?' then
en_value = en_value:sub(1, -2)
add_warning(parms, -1, 'cvt_deprecated', loc_name .. '=' .. loc_value)
end
if en_value == nil then
if loc_value == '' then
add_warning(parms, 2, 'cvt_empty_option', loc_name)
else
add_warning(parms, 1, 'cvt_unknown_option', loc_name .. '=' .. loc_value)
end
elseif en_value == '' then
en_value = nil -- an ignored option like adj=off
elseif type(en_value) == 'string' and en_value:sub(1, 4) == 'opt_' then
for _, v in ipairs(split(en_value, ',')) do
local lhs, rhs = v:match('^(.-)=(.+)$')
if rhs then
parms[lhs] = tonumber(rhs) or rhs
else
parms[v] = true
end
end
en_value = nil
end
end
parms[en_name] = en_value
else
add_warning(parms, 1, 'cvt_unknown_option', loc_name .. '=' .. loc_value)
end
end
local abbr_entered = parms.abbr
local cfg_abbr = config.abbr
if cfg_abbr then
-- Don't warn if invalid because every convert would show that warning.
if cfg_abbr == 'on always' then
parms.abbr = 'on'
elseif cfg_abbr == 'off always' then
parms.abbr = 'off'
elseif parms.abbr == nil then
if cfg_abbr == 'on default' then
parms.abbr = 'on'
elseif cfg_abbr == 'off default' then
parms.abbr = 'off'
end
end
end
if parms.abbr then
if parms.abbr == 'unit' then
parms.abbr = 'on'
parms.number_word = true
end
parms.abbr_org = parms.abbr -- original abbr, before any flip
elseif parms.opt_hand_hh then
parms.abbr_org = 'on'
parms.abbr = 'on'
else
parms.abbr = 'out' -- default is to abbreviate output only (use symbol, not name)
end
if parms.opt_order_out then
-- Disable options that do not work in a useful way with order=out.
parms.opt_flip = nil -- override adj=flip
parms.opt_spell_in = nil
parms.opt_spell_out = nil
parms.opt_spell_upper = nil
end
if parms.opt_spell_out and not abbr_entered then
parms.abbr = 'off' -- should show unit name when spelling the output value
end
if parms.opt_flip then
local function swap_in_out(option)
local value = parms[option]
if value == 'in' then
parms[option] = 'out'
elseif value == 'out' then
parms[option] = 'in'
end
end
swap_in_out('abbr')
swap_in_out('lk')
if parms.opt_spell_in and not parms.opt_spell_out then
-- For simplicity, and because it does not appear to be needed,
-- user cannot set an option to spell the output only.
parms.opt_spell_in = nil
parms.opt_spell_out = true
end
end
if parms.opt_spell_upper then
parms.spell_upper = parms.opt_flip and 'out' or 'in'
end
if parms.opt_table or parms.opt_tablecen then
if abbr_entered == nil and parms.lk == nil then
parms.opt_values = true
end
parms.table_align = parms.opt_table and 'right' or 'center'
end
if parms.table_align or parms.opt_sortable_on then
parms.need_table_or_sort = true
end
local disp_joins = text_code.disp_joins
local default_joins = disp_joins['b']
parms.join_between = default_joins[3] or '; '
local disp = parms.disp
if disp == nil then -- special case for the most common setting
parms.joins = default_joins
elseif disp == 'x' then
-- Later, parms.joins is set from the input parameters.
else
-- Old template does this.
local abbr = parms.abbr
if disp == 'slash' then
if abbr_entered == nil then
disp = 'slash-nbsp'
elseif abbr == 'in' or abbr == 'out' then
disp = 'slash-sp'
else
disp = 'slash-nosp'
end
elseif disp == 'sqbr' then
if abbr == 'on' then
disp = 'sqbr-nbsp'
else
disp = 'sqbr-sp'
end
end
parms.joins = disp_joins[disp] or default_joins
parms.join_between = parms.joins[3] or parms.join_between
parms.wantname = parms.joins.wantname
end
if (en_default and not parms.opt_lang_local and (parms[1] or ''):find('%d')) or parms.opt_lang_en then
from_en_table = nil
end
if en_default and from_en_table then
-- For hiwiki: localized symbol/name is defined with the US symbol/name field,
-- and is used if output uses localized numbers.
parms.opt_sp_us = true
end
return true
end
local function get_values(parms)
-- If successful, update parms and return true, v, i where
-- v = table of input values
-- i = index to next entry in parms after those processed here
-- or return false, t where t is an error message table.
local valinfo = collection() -- numbered table of input values
local range = collection() -- numbered table of range items (having, for example, 2 range items requires 3 input values)
local had_nocomma -- true if removed "nocomma" kludge from second parameter (like "tonocomma")
local parm2 = strip(parms[2])
if parm2 and parm2:sub(-7, -1) == 'nocomma' then
parms[2] = strip(parm2:sub(1, -8))
parms.opt_nocomma = true
had_nocomma = true
end
local function extractor(i)
-- If the parameter is not a value, try unpacking it as a range ("1-23" for "1 to 23").
-- However, "-1-2/3" is a negative fraction (-1⅔), so it must be extracted first.
-- Do not unpack a parameter if it is like "3-1/2" which is sometimes incorrectly
-- used instead of "3+1/2" (and which should not be interpreted as "3 to ½").
-- Unpacked items are inserted into the parms table.
-- The tail recursion allows combinations like "1x2 to 3x4".
local valstr = strip(parms[i]) -- trim so any '-' as a negative sign will be at start
local success, result = extract_number(parms, valstr, i > 1)
if not success and valstr and i < 20 then -- check i to limit abuse
local lhs, sep, rhs = valstr:match('^(%S+)%s+(%S+)%s+(%S.*)')
if lhs and not (sep == '-' and rhs:match('/')) then
if sep:find('%d') then
return success, result -- to reject {{convert|1 234 567|m}} with a decent message (en only)
end
parms[i] = rhs
table.insert(parms, i, sep)
table.insert(parms, i, lhs)
return extractor(i)
end
if not valstr:match('%-.*/') then
for _, sep in ipairs(text_code.ranges.words) do
local start, stop = valstr:find(sep, 2, true) -- start at 2 to skip any negative sign for range '-'
if start then
parms[i] = valstr:sub(stop + 1)
table.insert(parms, i, sep)
table.insert(parms, i, valstr:sub(1, start - 1))
return extractor(i)
end
end
end
end
return success, result
end
local i = 1
local is_change
while true do
local success, info = extractor(i) -- need to set parms.opt_nocomma before calling this
if not success then return false, info end
i = i + 1
if is_change then
info.is_change = true -- value is after "±" and so is a change (significant for range like {{convert|5|±|5|°C}})
is_change = nil
end
valinfo:add(info)
local range_item = get_range(strip(parms[i]))
if not range_item then
break
end
i = i + 1
range:add(range_item)
if type(range_item) == 'table' then
-- For range "x", if append unit to some values, append it to all.
parms.in_range_x = parms.in_range_x or range_item.in_range_x
parms.out_range_x = parms.out_range_x or range_item.out_range_x
parms.abbr_range_x = parms.abbr_range_x or range_item.abbr_range_x
is_change = range_item.is_range_change
end
end
if range.n > 0 then
if range.n > 30 then -- limit abuse, although 4 is a more likely upper limit
return false, { 'cvt_invalid_num' } -- misleading message but it will do
end
parms.range = range
elseif had_nocomma then
return false, { 'cvt_unknown', parm2 }
end
return true, valinfo, i
end
local function simple_get_values(parms)
-- If input is like "{{convert|valid_value|valid_unit|...}}",
-- return true, i, in_unit, in_unit_table
-- i = index in parms of what follows valid_unit, if anything.
-- The valid_value is not negative and does not use a fraction, and
-- no options requiring further processing of the input are used.
-- Otherwise, return nothing or return false, parm1 for caller to interpret.
-- Testing shows this function is successful for 96% of converts in articles,
-- and that on average it speeds up converts by 8%.
local clean = to_en(strip(parms[1] or ''), parms)
if parms.opt_ri or parms.opt_spell_in or #clean > 10 or not clean:match('^[0-9.]+$') then
return false, clean
end
local value = tonumber(clean)
if not value then return end
local info = {
value = value,
altvalue = value,
singular = (value == 1),
clean = clean,
show = with_separator(parms, clean),
}
local in_unit = strip(parms[2])
local success, in_unit_table = lookup(parms, in_unit, 'no_combination')
if not success then return end
in_unit_table.valinfo = { info }
return true, 3, in_unit, in_unit_table
end
local function wikidata_call(parms, operation, ...)
-- Return true, s where s is the result of a Wikidata operation,
-- or return false, t where t is an error message table.
local function worker(...)
wikidata_code = wikidata_code or require(wikidata_module)
wikidata_data = wikidata_data or mw.loadData(wikidata_data_module)
return wikidata_code[operation](wikidata_data, ...)
end
local success, status, result = pcall(worker, ...)
if success then
return status, result
end
if parms.opt_sortable_debug then
-- Use debug=yes to crash if an error while accessing Wikidata.
error('Error accessing Wikidata: ' .. status, 0)
end
return false, { 'cvt_wd_fail' }
end
local function get_parms(parms, args)
-- If successful, update parms and return true, unit where
-- parms is a table of all arguments passed to the template
-- converted to named arguments, and
-- unit is the input unit table;
-- or return false, t where t is an error message table.
-- For special processing (not a convert), can also return
-- true, wikitext where wikitext is the final result.
-- The returned input unit table may be for a fake unit using the specified
-- unit code as the symbol and name, and with bad_mcode = message code table.
-- MediaWiki removes leading and trailing whitespace from the values of
-- named arguments. However, the values of numbered arguments include any
-- whitespace entered in the template, and whitespace is used by some
-- parameters (example: the numbered parameters associated with "disp=x").
local kv_pairs = {} -- table of input key:value pairs where key is a name; needed because cannot iterate parms and add new fields to it
for k, v in pairs(args) do
if type(k) == 'number' or k == 'test' then -- parameter "test" is reserved for testing and is not translated
parms[k] = v
else
kv_pairs[k] = v
end
end
if parms.test == 'wikidata' then
local ulookup = function (ucode)
-- Use empty table for parms so it does not accumulate results when used repeatedly.
return lookup({}, ucode, 'no_combination')
end
return wikidata_call(parms, '_listunits', ulookup)
end
local success, msg = translate_parms(parms, kv_pairs)
if not success then return false, msg end
if parms.input then
success, msg = wikidata_call(parms, '_adjustparameters', parms, 1)
if not success then return false, msg end
end
local success, i, in_unit, in_unit_table = simple_get_values(parms)
if not success then
if type(i) == 'string' and i:match('^NNN+$') then
-- Some infoboxes have examples like {{convert|NNN|m}} (3 or more "N").
-- Output an empty string for these.
return false, { 'cvt_no_output' }
end
local valinfo
success, valinfo, i = get_values(parms)
if not success then return false, valinfo end
in_unit = strip(parms[i])
i = i + 1
success, in_unit_table = lookup(parms, in_unit, 'no_combination')
if not success then
in_unit = in_unit or ''
if parms.opt_ignore_error then -- display given unit code with no error (for use with {{val}})
in_unit_table = '' -- suppress error message and prevent processing of output unit
end
in_unit_table = setmetatable({
symbol = in_unit, name2 = in_unit, utype = in_unit,
scale = 1, default = '', defkey = '', linkey = '',
bad_mcode = in_unit_table }, unit_mt)
end
in_unit_table.valinfo = valinfo
end
if parms.test == 'msg' then
-- Am testing the messages produced when no output unit is specified, and
-- the input unit has a missing or invalid default.
-- Set two units for testing that.
-- LATER: Remove this code.
if in_unit == 'chain' then
in_unit_table.default = nil -- no default
elseif in_unit == 'rd' then
in_unit_table.default = "ft!X!m" -- an invalid expression
end
end
in_unit_table.inout = 'in' -- this is an input unit
if not parms.range then
local success, inext, composite_unit = get_composite(parms, i, in_unit_table)
if not success then return false, inext end
if composite_unit then
in_unit_table = composite_unit
i = inext
end
end
if in_unit_table.builtin == 'mach' then
-- As with old template, a number following Mach as the input unit is the altitude.
-- That is deprecated: should use altitude_ft=NUMBER or altitude_m=NUMBER.
local success, info
success = tonumber(parms[i]) -- this will often work and will give correct result for values like 2e4 without forcing output scientific notation
if success then
info = { value = success }
else
success, info = extract_number(parms, parms[i], false, true)
end
if success then
i = i + 1
in_unit_table.altitude = info.value
end
end
local word = strip(parms[i])
i = i + 1
local precision, is_bad_precision
local function set_precision(text)
local number, is_integer = get_number(text)
if number then
if is_integer then
precision = number
else
precision = text
is_bad_precision = true
end
return true -- text was used for precision, good or bad
end
end
if word and not set_precision(word) then
parms.out_unit = parms.out_unit or word
if set_precision(strip(parms[i])) then
i = i + 1
end
end
if parms.opt_adj_mid then
word = parms[i]
i = i + 1
if word then -- mid-text words
if word:sub(1, 1) == '-' then
parms.mid = word
else
parms.mid = ' ' .. word
end
end
end
if parms.opt_one_preunit then
parms[parms.opt_flip and 'preunit2' or 'preunit1'] = preunits(1, parms[i])
i = i + 1
end
if parms.disp == 'x' then
-- Following is reasonably compatible with the old template.
local first = parms[i] or ''
local second = parms[i+1] or ''
i = i + 2
if strip(first) == '' then -- user can enter ' ' rather than ' ' to avoid the default
first = ' [ ' .. first
second = ' ]' .. second
end
parms.joins = { first, second }
elseif parms.opt_two_preunits then
local p1, p2 = preunits(2, parms[i], parms[i+1])
i = i + 2
if parms.preunit1 then
-- To simplify documentation, allow unlikely use of adj=pre with disp=preunit
-- (however, an output unit must be specified with adj=pre and with disp=preunit).
parms.preunit1 = parms.preunit1 .. p1
parms.preunit2 = p2
else
parms.preunit1, parms.preunit2 = p1, p2
end
end
if precision == nil then
if set_precision(strip(parms[i])) then
i = i + 1
end
end
if is_bad_precision then
add_warning(parms, 1, 'cvt_bad_prec', precision)
else
parms.precision = precision
end
for j = i, i + 3 do
local parm = parms[j] -- warn if find a non-empty extraneous parameter
if parm and parm:match('%S') then
add_warning(parms, 1, 'cvt_unknown_option', parm)
break
end
end
return true, in_unit_table
end
local function record_default_precision(parms, out_current, precision)
-- If necessary, adjust parameters and return a possibly adjusted precision.
-- When converting a range of values where a default precision is required,
-- that default is calculated for each value because the result sometimes
-- depends on the precise input and output values. This function may cause
-- the entire convert process to be repeated in order to ensure that the
-- same default precision is used for each individual convert.
-- If that were not done, a range like 1000 to 1000.4 may give poor results
-- because the first output could be heavily rounded, while the second is not.
-- For range 1000.4 to 1000, this function can give the second convert the
-- same default precision that was used for the first.
if not parms.opt_round_each then
local maxdef = out_current.max_default_precision
if maxdef then
if maxdef < precision then
parms.do_convert_again = true
out_current.max_default_precision = precision
else
precision = out_current.max_default_precision
end
else
out_current.max_default_precision = precision
end
end
return precision
end
local function default_precision(parms, invalue, inclean, denominator, outvalue, in_current, out_current, extra)
-- Return a default value for precision (an integer like 2, 0, -2).
-- If denominator is not nil, it is the value of the denominator in inclean.
-- Code follows procedures used in old template.
local fudge = 1e-14 -- {{Order of magnitude}} adds this, so we do too
local prec, minprec, adjust
local subunit_ignore_trailing_zero
local subunit_more_precision -- kludge for "in" used in input like "|2|ft|6|in"
local composite = in_current.composite
if composite then
subunit_ignore_trailing_zero = true -- input "|2|st|10|lb" has precision 0, not -1
if composite[#composite].exception == 'subunit_more_precision' then
subunit_more_precision = true -- do not use standard precision with input like "|2|ft|6|in"
end
end
if denominator and denominator > 0 then
prec = math.max(log10(denominator), 1)
else
-- Count digits after decimal mark, handling cases like '12.345e6'.
local exponent
local integer, dot, decimals, expstr = inclean:match('^(%d*)(%.?)(%d*)(.*)')
local e = expstr:sub(1, 1)
if e == 'e' or e == 'E' then
exponent = tonumber(expstr:sub(2))
end
if dot == '' then
prec = subunit_ignore_trailing_zero and 0 or -integer:match('0*$'):len()
else
prec = #decimals
end
if exponent then
-- So '1230' and '1.23e3' both give prec = -1, and '0.00123' and '1.23e-3' give 5.
prec = prec - exponent
end
end
if in_current.istemperature and out_current.istemperature then
-- Converting between common temperatures (°C, °F, °R, K); not keVT.
-- Kelvin value can be almost zero, or small but negative due to precision problems.
-- Also, an input value like -300 C (below absolute zero) gives negative kelvins.
-- Calculate minimum precision from absolute value.
adjust = 0
local kelvin = abs((invalue - in_current.offset) * in_current.scale)
if kelvin < 1e-8 then -- assume nonzero due to input or calculation precision problem
minprec = 2
else
minprec = 2 - floor(log10(kelvin) + fudge) -- 3 sigfigs in kelvin
end
else
if invalue == 0 or outvalue <= 0 then
-- We are never called with a negative outvalue, but it might be zero.
-- This is special-cased to avoid calculation exceptions.
return record_default_precision(parms, out_current, 0)
end
if out_current.exception == 'integer_more_precision' and floor(invalue) == invalue then
-- With certain output units that sometimes give poor results
-- with default rounding, use more precision when the input
-- value is equal to an integer. An example of a poor result
-- is when input 50 gives a smaller output than input 49.5.
-- Experiment shows this helps, but it does not eliminate all
-- surprises because it is not clear whether "50" should be
-- interpreted as "from 45 to 55" or "from 49.5 to 50.5".
adjust = -log10(in_current.scale)
elseif subunit_more_precision then
-- Conversion like "{{convert|6|ft|1|in|cm}}" (where subunit is "in")
-- has a non-standard adjust value, to give more output precision.
adjust = log10(out_current.scale) + 2
else
adjust = log10(abs(invalue / outvalue))
end
adjust = adjust + log10(2)
-- Ensure that the output has at least two significant figures.
minprec = 1 - floor(log10(outvalue) + fudge)
end
if extra then
adjust = extra.adjust or adjust
minprec = extra.minprec or minprec
end
return record_default_precision(parms, out_current, math.max(floor(prec + adjust), minprec))
end
local function convert(parms, invalue, info, in_current, out_current)
-- Convert given input value from one unit to another.
-- Return output_value (a number) if a simple convert, or
-- return f, t where
-- f = true, t = table of information with results, or
-- f = false, t = error message table.
local inscale = in_current.scale
local outscale = out_current.scale
if not in_current.iscomplex and not out_current.iscomplex then
return invalue * (inscale / outscale) -- minimize overhead for most common case
end
if in_current.invert or out_current.invert then
-- Inverted units, such as inverse length, inverse time, or
-- fuel efficiency. Built-in units do not have invert set.
if (in_current.invert or 1) * (out_current.invert or 1) < 0 then
return 1 / (invalue * inscale * outscale)
end
return invalue * (inscale / outscale)
elseif in_current.offset then
-- Temperature (there are no built-ins for this type of unit).
if info.is_change then
return invalue * (inscale / outscale)
end
return (invalue - in_current.offset) * (inscale / outscale) + out_current.offset
else
-- Built-in unit.
local in_builtin = in_current.builtin
local out_builtin = out_current.builtin
if in_builtin and out_builtin then
if in_builtin == out_builtin then
return invalue
end
-- There are no cases (yet) where need to convert from one
-- built-in unit to another, so this should never occur.
return false, { 'cvt_bug_convert' }
end
if in_builtin == 'mach' or out_builtin == 'mach' then
-- Should check that only one altitude is given but am planning to remove
-- in_current.altitude (which can only occur when Mach is the input unit),
-- and out_current.altitude cannot occur.
local alt = parms.altitude_ft or in_current.altitude
if not alt and parms.altitude_m then
alt = parms.altitude_m / 0.3048 -- 1 ft = 0.3048 m
end
local spd = speed_of_sound(alt)
if in_builtin == 'mach' then
inscale = spd
return invalue * (inscale / outscale)
end
outscale = spd
local adjust = 0.1 / inscale
return true, {
outvalue = invalue * (inscale / outscale),
adjust = log10(adjust) + log10(2),
}
elseif in_builtin == 'hand' then
-- 1 hand = 4 inches; 1.2 hands = 6 inches.
-- Decimals of a hand are only defined for the first digit, and
-- the first fractional digit should be a number of inches (1, 2 or 3).
-- However, this code interprets the entire fractional part as the number
-- of inches / 10 (so 1.75 inches would be 0.175 hands).
-- A value like 12.3 hands is exactly 12*4 + 3 inches; base default precision on that.
local integer, fracpart = math.modf(invalue)
local inch_value = 4 * integer + 10 * fracpart -- equivalent number of inches
local factor = inscale / outscale
if factor == 4 then
-- Am converting to inches: show exact result, and use "inches" not "in" by default.
if parms.abbr_org == nil then
out_current.usename = true
end
local show = format('%g', abs(inch_value)) -- show and clean are unsigned
if not show:find('e', 1, true) then
return true, {
invalue = inch_value,
outvalue = inch_value,
clean = show,
show = show,
}
end
end
local outvalue = (integer + 2.5 * fracpart) * factor
local fracstr = info.clean:match('%.(.*)') or ''
local fmt
if fracstr == '' then
fmt = '%.0f'
else
fmt = '%.' .. format('%d', #fracstr - 1) .. 'f'
end
return true, {
invalue = inch_value,
clean = format(fmt, inch_value),
outvalue = outvalue,
minprec = 0,
}
end
end
return false, { 'cvt_bug_convert' } -- should never occur
end
local function user_style(parms, i)
-- Return text for a user-specified style for a table cell, or '' if none,
-- given i = 1 (input style) or 2 (output style).
local style = parms[(i == 1) and 'stylein' or 'styleout']
if style then
style = style:gsub('"', '')
if style ~= '' then
if style:sub(-1) ~= ';' then
style = style .. ';'
end
return style
end
end
return ''
end
local function make_table_or_sort(parms, invalue, info, in_current, scaled_top)
-- Set options to handle output for a table or a sort key, or both.
-- The text sort key is based on the value resulting from converting
-- the input to a fake base unit with scale = 1, and other properties
-- required for a conversion derived from the input unit.
-- For other modules, return the sort key in a hidden span element, and
-- the scaled value used to generate the sort key.
-- If scaled_top is set, it is the scaled value of the numerator of a per unit
-- to be combined with this unit (the denominator) to make the sort key.
-- Scaling only works with units that convert with a factor (not temperature).
local sortkey, scaled_value
if parms.opt_sortable_on then
local base = { -- a fake unit with enough fields for a valid convert
scale = 1,
invert = in_current.invert and 1,
iscomplex = in_current.iscomplex,
offset = in_current.offset and 0,
}
local outvalue, extra = convert(parms, invalue, info, in_current, base)
if extra then
outvalue = extra.outvalue
end
if in_current.istemperature then
-- Have converted to kelvin; assume numbers close to zero have a
-- rounding error and should be zero.
if abs(outvalue) < 1e-12 then
outvalue = 0
end
end
if scaled_top and outvalue ~= 0 then
outvalue = scaled_top / outvalue
end
scaled_value = outvalue
if not valid_number(outvalue) then
if outvalue < 0 then
sortkey = '1000000000000000000'
else
sortkey = '9000000000000000000'
end
elseif outvalue == 0 then
sortkey = '5000000000000000000'
else
local mag = floor(log10(abs(outvalue)) + 1e-14)
local prefix
if outvalue > 0 then
prefix = 7000 + mag
else
prefix = 2999 - mag
outvalue = outvalue + 10^(mag+1)
end
sortkey = format('%d', prefix) .. format('%015.0f', floor(outvalue * 10^(14-mag)))
end
end
local sortspan
if sortkey and not parms.table_align then
sortspan = parms.opt_sortable_debug and
'<span data-sort-value="' .. sortkey .. '♠"><span style="border:1px solid">' .. sortkey .. '♠</span></span>' or
'<span data-sort-value="' .. sortkey .. '♠"></span>'
parms.join_before = sortspan
end
if parms.table_align then
local sort
if sortkey then
sort = ' data-sort-value="' .. sortkey .. '"'
if parms.opt_sortable_debug then
parms.join_before = '<span style="border:1px solid">' .. sortkey .. '</span>'
end
else
sort = ''
end
local style = 'style="text-align:' .. parms.table_align .. ';'
local joins = {}
for i = 1, 2 do
joins[i] = (i == 1 and '' or '\n|') .. style .. user_style(parms, i) .. '"' .. sort .. '|'
end
parms.table_joins = joins
end
return sortspan, scaled_value
end
local cvt_to_hand
local function cvtround(parms, info, in_current, out_current)
-- Return true, t where t is a table with the conversion results; fields:
-- show = rounded, formatted string with the result of converting value in info,
-- using the rounding specified in parms.
-- singular = true if result (after rounding and ignoring any negative sign)
-- is "1", or like "1.00", or is a fraction with value < 1;
-- (and more fields shown below, and a calculated 'absvalue' field).
-- or return false, t where t is an error message table.
-- Input info.clean uses en digits (it has been translated, if necessary).
-- Output show uses en or non-en digits as appropriate, or can be spelled.
if out_current.builtin == 'hand' then
return cvt_to_hand(parms, info, in_current, out_current)
end
local invalue = in_current.builtin == 'hand' and info.altvalue or info.value
local outvalue, extra = convert(parms, invalue, info, in_current, out_current)
if parms.need_table_or_sort then
parms.need_table_or_sort = nil -- process using first input value only
make_table_or_sort(parms, invalue, info, in_current)
end
if extra then
if not outvalue then return false, extra end
invalue = extra.invalue or invalue
outvalue = extra.outvalue
end
if not valid_number(outvalue) then
return false, { 'cvt_invalid_num' }
end
local isnegative
if outvalue < 0 then
isnegative = true
outvalue = -outvalue
end
local precision, show, exponent
local denominator = out_current.frac
if denominator then
show = fraction_table(outvalue, denominator)
else
precision = parms.precision
if not precision then
if parms.sigfig then
show, exponent = make_sigfig(outvalue, parms.sigfig)
elseif parms.opt_round then
local n = parms.opt_round
if n == 0.5 then
local integer, fracpart = math.modf(floor(2 * outvalue + 0.5) / 2)
if fracpart == 0 then
show = format('%.0f', integer)
else
show = format('%.1f', integer + fracpart)
end
else
show = format('%.0f', floor((outvalue / n) + 0.5) * n)
end
elseif in_current.builtin == 'mach' then
local sigfig = info.clean:gsub('^[0.]+', ''):gsub('%.', ''):len() + 1
show, exponent = make_sigfig(outvalue, sigfig)
else
local inclean = info.clean
if extra then
inclean = extra.clean or inclean
show = extra.show
end
if not show then
precision = default_precision(parms, invalue, inclean, info.denominator, outvalue, in_current, out_current, extra)
end
end
end
end
if precision then
if precision >= 0 then
local fudge
if precision <= 8 then
-- Add a fudge to handle common cases of bad rounding due to inability
-- to precisely represent some values. This makes the following work:
-- {{convert|-100.1|C|K}} and {{convert|5555000|um|m|2}}.
-- Old template uses #expr round, which invokes PHP round().
-- LATER: Investigate how PHP round() works.
fudge = 2e-14
else
fudge = 0
end
local fmt = '%.' .. format('%d', precision) .. 'f'
local success
success, show = pcall(format, fmt, outvalue + fudge)
if not success then
return false, { 'cvt_big_prec', tostring(precision) }
end
else
precision = -precision -- #digits to zero (in addition to any digits after dot)
local shift = 10 ^ precision
show = format('%.0f', outvalue/shift)
if show ~= '0' then
exponent = #show + precision
end
end
end
local t = format_number(parms, show, exponent, isnegative)
if type(show) == 'string' then
-- Set singular using match because on some systems 0.99999999999999999 is 1.0.
if exponent then
t.singular = (exponent == 1 and show:match('^10*$'))
else
t.singular = (show == '1' or show:match('^1%.0*$'))
end
else
t.fraction_table = show
t.singular = (outvalue <= 1) -- cannot have 'fraction == 1', but if it were possible it would be singular
end
t.raw_absvalue = outvalue -- absolute value before rounding
return true, setmetatable(t, {
__index = function (self, key)
if key == 'absvalue' then
-- Calculate absolute value after rounding, if needed.
local clean, exponent = rawget(self, 'clean'), rawget(self, 'exponent')
local value = tonumber(clean) -- absolute value (any negative sign has been ignored)
if exponent then
value = value * 10^exponent
end
rawset(self, key, value)
return value
end
end })
end
function cvt_to_hand(parms, info, in_current, out_current)
-- Convert input to hands, inches.
-- Return true, t where t is a table with the conversion results;
-- or return false, t where t is an error message table.
if parms.abbr_org == nil then
out_current.usename = true -- default is to show name not symbol
end
local precision = parms.precision
local frac = out_current.frac
if not frac and precision and precision > 1 then
frac = (precision == 2) and 2 or 4
end
local out_next = out_current.out_next
if out_next then
-- Use magic knowledge to determine whether the next unit is inches without requiring i18n.
-- The following ensures that when the output combination "hand in" is used, the inches
-- value is rounded to match the hands value. Also, displaying say "61½" instead of 61.5
-- is better as 61.5 implies the value is not 61.4.
if out_next.exception == 'subunit_more_precision' then
out_next.frac = frac
end
end
-- Convert to inches; calculate hands from that.
local dummy_unit_table = { scale = out_current.scale / 4, frac = frac }
local success, outinfo = cvtround(parms, info, in_current, dummy_unit_table)
if not success then return false, outinfo end
local tfrac = outinfo.fraction_table
local inches = outinfo.raw_absvalue
if tfrac then
inches = floor(inches) -- integer part only; fraction added later
else
inches = floor(inches + 0.5) -- a hands measurement never shows decimals of an inch
end
local hands, inches = divide(inches, 4)
outinfo.absvalue = hands + inches/4 -- supposed to be the absolute rounded value, but this is close enough
local inchstr = tostring(inches) -- '0', '1', '2' or '3'
if precision and precision <= 0 then -- using negative or 0 for precision rounds to nearest hand
hands = floor(outinfo.raw_absvalue/4 + 0.5)
inchstr = ''
elseif tfrac then
-- Always show an integer before fraction (like "15.0½") because "15½" means 15-and-a-half hands.
inchstr = numdot .. format_fraction(parms, 'out', false, inchstr, tfrac.numstr, tfrac.denstr)
else
inchstr = numdot .. from_en(inchstr)
end
outinfo.show = outinfo.sign .. with_separator(parms, format('%.0f', hands)) .. inchstr
return true, outinfo
end
local function evaluate_condition(value, condition)
-- Return true or false from applying a conditional expression to value,
-- or throw an error if invalid.
-- A very limited set of expressions is supported:
-- v < 9
-- v * 9 < 9
-- where
-- 'v' is replaced with value
-- 9 is any number (as defined by Lua tonumber)
-- only en digits are accepted
-- '<' can also be '<=' or '>' or '>='
-- In addition, the following form is supported:
-- LHS and RHS
-- where
-- LHS, RHS = any of above expressions.
local function compare(value, text)
local arithop, factor, compop, limit = text:match('^%s*v%s*([*]?)(.-)([<>]=?)(.*)$')
if arithop == nil then
error('Invalid default expression', 0)
elseif arithop == '*' then
factor = tonumber(factor)
if factor == nil then
error('Invalid default expression', 0)
end
value = value * factor
end
limit = tonumber(limit)
if limit == nil then
error('Invalid default expression', 0)
end
if compop == '<' then
return value < limit
elseif compop == '<=' then
return value <= limit
elseif compop == '>' then
return value > limit
elseif compop == '>=' then
return value >= limit
end
error('Invalid default expression', 0) -- should not occur
end
local lhs, rhs = condition:match('^(.-%W)and(%W.*)')
if lhs == nil then
return compare(value, condition)
end
return compare(value, lhs) and compare(value, rhs)
end
local function get_default(value, unit_table)
-- Return true, s where s = name of unit's default output unit,
-- or return false, t where t is an error message table.
-- Some units have a default that depends on the input value
-- (the first value if a range of values is used).
-- If '!' is in the default, the first bang-delimited field is an
-- expression that uses 'v' to represent the input value.
-- Example: 'v < 120 ! small ! big ! suffix' (suffix is optional)
-- evaluates 'v < 120' as a boolean with result
-- 'smallsuffix' if (value < 120), or 'bigsuffix' otherwise.
-- Input must use en digits and '.' decimal mark.
local default = data_code.default_exceptions[unit_table.defkey or unit_table.symbol] or unit_table.default
if not default then
local per = unit_table.per
if per then
local function a_default(v, u)
local success, ucode = get_default(v, u)
if not success then
return '?' -- an unlikely error has occurred; will cause lookup of default to fail
end
-- Attempt to use only the first unit if a combination or output multiple.
-- This is not bulletproof but should work for most cases.
-- Where it does not work, the convert will need to specify the wanted output unit.
local t = all_units[ucode]
if t then
local combo = t.combination
if combo then
-- For a multiple like ftin, the "first" unit (ft) is last in the combination.
local i = t.multiple and table_len(combo) or 1
ucode = combo[i]
end
else
-- Try for an automatically generated combination.
local item = ucode:match('^(.-)%+') or ucode:match('^(%S+)%s')
if all_units[item] then
return item
end
end
return ucode
end
local unit1, unit2 = per[1], per[2]
local def1 = (unit1 and a_default(value, unit1) or unit_table.vprefix or '')
local def2 = a_default(1, unit2) -- 1 because per unit of denominator
return true, def1 .. '/' .. def2
end
return false, { 'cvt_no_default', unit_table.symbol }
end
if default:find('!', 1, true) == nil then
return true, default
end
local t = split(default, '!')
if #t == 3 or #t == 4 then
local success, result = pcall(evaluate_condition, value, t[1])
if success then
default = result and t[2] or t[3]
if #t == 4 then
default = default .. t[4]
end
return true, default
end
end
return false, { 'cvt_bad_default', unit_table.symbol }
end
local linked_pages -- to record linked pages so will not link to the same page more than once
local function unlink(unit_table)
-- Forget that the given unit has previously been linked (if it has).
-- That is needed when processing a range of inputs or outputs when an id
-- for the first range value may have been evaluated, but only an id for
-- the last value is displayed, and that id may need to be linked.
linked_pages[unit_table.unitcode or unit_table] = nil
end
local function make_link(link, id, unit_table)
-- Return wikilink "[[link|id]]", possibly abbreviated as in examples:
-- [[Mile|mile]] --> [[mile]]
-- [[Mile|miles]] --> [[mile]]s
-- However, just id is returned if:
-- * no link given (so caller does not need to check if a link was defined); or
-- * link has previously been used during the current convert (to avoid overlinking).
local link_key
if unit_table then
link_key = unit_table.unitcode or unit_table
else
link_key = link
end
if not link or link == '' or linked_pages[link_key] then
return id
end
linked_pages[link_key] = true
-- Following only works for language en, but it should be safe on other wikis,
-- and overhead of doing it generally does not seem worthwhile.
local l = link:sub(1, 1):lower() .. link:sub(2)
if link == id or l == id then
return '[[' .. id .. ']]'
elseif link .. 's' == id or l .. 's' == id then
return '[[' .. id:sub(1, -2) .. ']]s'
else
return '[[' .. link .. '|' .. id .. ']]'
end
end
local function variable_name(clean, unit_table, exp_multiplier, key_id)
-- A unit name may depend on the value in some languages.
-- Parameter clean is the unsigned value in en digits, as a string.
-- It may represent a number ("1.0") or a fraction ("1+2/3").
-- In varname, fields are separated with "!" and are not empty.
-- A field for a unit using an SI prefix has the prefix name inserted,
-- replacing '#' if found, or before the field otherwise.
if clean:match('[./]') then -- float or fraction
if exp_multiplier then
clean = exp_multiplier -- force selection of name for a large integer
else
clean = 34.5 -- force selection of name for a float value
end
else
clean = tonumber(clean) * (exp_multiplier or 1)
end
local name1, vname
if key_id == 'pername' and unit_table.pername then
vname = unit_table.pername
elseif unit_table.varname then
local splitvname = split(unit_table.varname, '!')
name1 = unit_table.name1
vname = mw.language.getContentLanguage():convertPlural(clean, name1, unpack(splitvname))
else
return clean == 1 and unit_table.name1 or unit_table.name2
end
if vname == name1 then
-- SI prefix (if any) has been inserted by unit_prefixed_mt.
else
local si_name = rawget(unit_table, 'si_name') or ''
local pos = vname:find('#', 1, true)
if pos then
vname = vname:sub(1, pos - 1) .. si_name .. vname:sub(pos + 1)
else
vname = si_name .. vname
end
end
return vname
end
local function linked_id(parms, unit_table, key_id, want_link, clean, exp_multiplier)
-- Return final unit id (symbol or name), optionally with a wikilink,
-- and update unit_table.sep if required.
-- key_id is one of: 'symbol', 'sym_us', 'name1', 'name1_us', 'name2', 'name2_us', 'pername'.
local abbr_on = (key_id == 'symbol' or key_id == 'sym_us')
if abbr_on and want_link then
local symlink = rawget(unit_table, 'symlink')
if symlink then
return symlink -- for exceptions that have the linked symbol built-in
end
end
local multiplier = rawget(unit_table, 'multiplier')
local per = unit_table.per
if per then
local paren1, paren2 = '', '' -- possible parentheses around bottom unit
local unit1 = per[1] -- top unit_table, or nil
local unit2 = per[2] -- bottom unit_table
if abbr_on then
if not unit1 then
unit_table.sep = '' -- no separator in "$2/acre"
end
if not want_link then
local symbol = unit_table.symbol_raw
if symbol then
return symbol -- for exceptions that have the symbol built-in
end
end
if (unit2.symbol):find('⋅', 1, true) then
paren1, paren2 = '(', ')'
end
end
local key_id2 -- unit2 is always singular
if key_id == 'name2' then
key_id2 = 'name1'
elseif key_id == 'name2_us' then
key_id2 = 'name1_us'
else
key_id2 = key_id
end
if key_id2 == 'name1' or key_id2 == 'name1_us' then
key_id2 = unit2.pername and 'pername' or key_id2 -- ukwiki has some units with a different name in "per unitname"
end
local result
if abbr_on then
result = '/'
elseif omitsep then
result = per_word
elseif unit1 then
result = ' ' .. per_word .. ' '
else
result = per_word .. ' '
end
if want_link and unit_table.link then
if varname and not abbr_on then
result = (unit1 and variable_name(clean, unit1, exp_multiplier) or '') .. result .. variable_name('1', unit2, exp_multiplier, key_id2)
else
result = (unit1 and linked_id(parms, unit1, key_id, false, clean) or '') .. result .. linked_id(parms, unit2, key_id2, false, '1')
end
if omit_separator(result) then
unit_table.sep = ''
end
return make_link(unit_table.link, result, unit_table)
end
if unit1 then
result = linked_id(parms, unit1, key_id, want_link, clean) .. result
if unit1.sep then
unit_table.sep = unit1.sep
end
elseif omitsep then
unit_table.sep = ''
end
return result .. paren1 .. linked_id(parms, unit2, key_id2, want_link, '1') .. paren2
end
if multiplier then
-- A multiplier (like "100" in "100km") forces the unit to be plural.
multiplier = from_en(multiplier)
if not omitsep then
multiplier = multiplier .. (abbr_on and ' ' or ' ')
end
if not abbr_on then
if key_id == 'name1' then
key_id = 'name2'
elseif key_id == 'name1_us' then
key_id = 'name2_us'
end
end
else
multiplier = ''
end
local id = unit_table.fixed_name or ((varname and not abbr_on) and variable_name(clean, unit_table, exp_multiplier, key_id) or unit_table[key_id])
if omit_separator(id) then
unit_table.sep = ''
end
if want_link then
local link = data_code.link_exceptions[unit_table.linkey or unit_table.symbol] or unit_table.link
if link then
local before = ''
local i = unit_table.customary
if i == 1 and parms.opt_sp_us then
i = 2 -- show "U.S." not "US"
end
if i == 3 and abbr_on then
i = 4 -- abbreviate "imperial" to "imp"
end
local customary = text_code.customary_units[i]
if customary then
-- LATER: This works for language en only, but it's esoteric so ignore for now.
local pertext
if id:sub(1, 1) == '/' then
-- Want unit "/USgal" to display as "/U.S. gal", not "U.S. /gal".
pertext = '/'
id = id:sub(2)
elseif id:sub(1, 4) == 'per ' then
-- Similarly want "per U.S. gallon", not "U.S. per gallon" (but in practice this is unlikely to be used).
pertext = 'per '
id = id:sub(5)
else
pertext = ''
end
-- Omit any "US"/"U.S."/"imp"/"imperial" from start of id since that will be inserted.
local removes = (i < 3) and { 'US ', 'US ', 'U.S. ', 'U.S. ' } or { 'imp ', 'imp ', 'imperial ' }
for _, prefix in ipairs(removes) do
local plen = #prefix
if id:sub(1, plen) == prefix then
id = id:sub(plen + 1)
break
end
end
before = pertext .. make_link(customary.link, customary[1]) .. ' '
end
id = before .. make_link(link, id, unit_table)
end
end
return multiplier .. id
end
local function make_id(parms, which, unit_table)
-- Return id, f where
-- id = unit name or symbol, possibly modified
-- f = true if id is a name, or false if id is a symbol
-- using the value for index 'which', and for 'in' or 'out' (unit_table.inout).
-- Result is '' if no symbol/name is to be used.
-- In addition, set unit_table.sep = ' ' or ' ' or ''
-- (the separator that caller will normally insert before the id).
if parms.opt_values then
unit_table.sep = ''
return ''
end
local inout = unit_table.inout
local info = unit_table.valinfo[which]
local lk = parms.lk
local want_link = (lk == 'on' or lk == inout)
local singular = info.singular
local want_name
local exp_multiplier
if unit_table.usename then
want_name = true
else
if parms.abbr_org == nil then
if parms.wantname then
want_name = true
end
if unit_table.usesymbol then
want_name = false
end
end
if want_name == nil then
local abbr = parms.abbr
if abbr == 'on' or abbr == inout or (abbr == 'mos' and inout == 'out') then
want_name = false
else
want_name = true
end
end
end
local key
if want_name then
if lk == nil and unit_table.builtin == 'hand' then
want_link = true
end
if parms.opt_use_nbsp then
unit_table.sep = ' '
else
unit_table.sep = ' '
end
if parms.opt_singular then
local value
if inout == 'in' then
value = info.value
else
value = info.absvalue
end
if value then -- some unusual units do not always set value field
value = abs(value)
singular = (0 < value and value < 1.0001)
end
end
if unit_table.engscale then
-- engscale: so "|1|e3kg" gives "1 thousand kilograms" (plural)
singular = false
exp_multiplier = 10^unit_table.engscale.exponent -- '1 gram' and '1 thousand grams', for example, may use different names for the unit in some languages
end
key = (parms.opt_adjectival or singular) and 'name1' or 'name2'
if parms.opt_sp_us then
key = key .. '_us'
end
else
if unit_table.builtin == 'hand' then
if parms.opt_hand_hh then
unit_table.symbol = 'hh' -- LATER: might want i18n applied to this
end
end
unit_table.sep = ' '
key = parms.opt_sp_us and 'sym_us' or 'symbol'
end
return linked_id(parms, unit_table, key, want_link, info.clean, exp_multiplier), want_name
end
local function decorate_value(parms, unit_table, which, enable_number_word)
-- If needed, update unit_table so values will be shown with extra information.
-- For consistency with the old template (but different from fmtpower),
-- the style to display powers of 10 includes "display:none" to allow some
-- browsers to copy, for example, "10³" as "10^3", rather than as "103".
-- The engscale table may have entries such as either of the following:
-- ["3"] = { "thousand", exponent = 3 },
-- ["3"] = { name1 = "A", varname = "B!C!D", exponent = 3 },
-- The first option always uses "thousand" as the exponent name.
-- The second option uses one of A, B, C, D as the exponent name, depending on the value.
local info
local engscale = unit_table.engscale
local prefix = unit_table.vprefix
if engscale or prefix then
info = unit_table.valinfo[which]
if info.decorated then
return -- do not redecorate if repeating convert
end
info.decorated = true
if engscale then
-- Range |10|-|20|e3km| gives '10×10³–20×10³' or '10–20 thousand'.
local inout = unit_table.inout
local abbr = parms.abbr
if (abbr == 'on' or abbr == inout) and not (unit_table.this_number_word or parms.number_word) then
info.show = info.show ..
'<span style="margin-left:0.2em">×<span style="margin-left:0.1em">' ..
from_en('10') ..
'</span></span><s style="display:none">^</s><sup>' ..
from_en(tostring(engscale.exponent)) .. '</sup>'
elseif enable_number_word then
local number_id
local name = engscale.varname and variable_name(info.clean, engscale) or engscale[1]
if parms.lk == 'on' or parms.lk == inout then
number_id = make_link(engscale.link, name)
else
number_id = name
end
-- WP:NUMERAL recommends " " in values like "12 million".
info.show = info.show .. (parms.opt_adjectival and '-' or ' ') .. number_id
end
end
if prefix then
info.show = prefix .. info.show
end
end
end
local function process_input(parms, in_current)
-- Processing required once per conversion.
-- Return block of text to represent input (value/unit).
if parms.opt_output_only or parms.opt_output_number_only or parms.opt_output_unit_only then
parms.joins = { '', '' }
return ''
end
local first_unit
local composite = in_current.composite -- nil or table of units
if composite then
first_unit = composite[1]
else
first_unit = in_current
end
local id1, want_name = make_id(parms, 1, first_unit)
local sep = first_unit.sep -- separator between value and unit, set by make_id
local preunit = parms.preunit1
if preunit then
sep = '' -- any separator is included in preunit
else
preunit = ''
end
if parms.opt_input_unit_only then
parms.joins = { '', '' }
if composite then
local parts = { id1 }
for i, unit in ipairs(composite) do
if i > 1 then
table.insert(parts, (make_id(parms, 1, unit)))
end
end
id1 = table.concat(parts, ' ')
end
if want_name and parms.opt_adjectival then
return preunit .. hyphenated(id1)
end
return preunit .. id1
end
if parms.opt_also_symbol and not composite and not parms.opt_flip then
local join1 = parms.joins[1]
if join1 == ' (' or join1 == ' [' then
parms.joins = { ' [' .. first_unit[parms.opt_sp_us and 'sym_us' or 'symbol'] .. ']' .. join1 , parms.joins[2] }
end
end
if in_current.builtin == 'mach' and first_unit.sep ~= '' then -- '' means omitsep with non-enwiki name
local prefix = id1 .. ' '
local range = parms.range
local valinfo = first_unit.valinfo
local result = prefix .. valinfo[1].show
if range then
-- For simplicity and because more not needed, handle one range item only.
local prefix2 = make_id(parms, 2, first_unit) .. ' '
result = range_text(range[1], want_name, parms, result, prefix2 .. valinfo[2].show, 'in', {spaced=true})
end
return preunit .. result
end
if composite then
-- Simplify: assume there is no range, and no decoration.
local mid = (not parms.opt_flip) and parms.mid or ''
local sep1 = ' '
local sep2 = ' '
if parms.opt_adjectival and want_name then
sep1 = '-'
sep2 = '-'
end
if omitsep and sep == '' then
-- Testing the id of the most significant unit should be sufficient.
sep1 = ''
sep2 = ''
end
local parts = { first_unit.valinfo[1].show .. sep1 .. id1 }
for i, unit in ipairs(composite) do
if i > 1 then
table.insert(parts, unit.valinfo[1].show .. sep1 .. (make_id(parms, 1, unit)))
end
end
return table.concat(parts, sep2) .. mid
end
local add_unit = (parms.abbr == 'mos') or
parms[parms.opt_flip and 'out_range_x' or 'in_range_x'] or
(not want_name and parms.abbr_range_x)
local range = parms.range
if range and not add_unit then
unlink(first_unit)
end
local id = range and make_id(parms, range.n + 1, first_unit) or id1
local extra, was_hyphenated = hyphenated_maybe(parms, want_name, sep, id, 'in')
if was_hyphenated then
add_unit = false
end
local result
local valinfo = first_unit.valinfo
if range then
for i = 0, range.n do
local enable_number_word
if i == range.n then
add_unit = false
enable_number_word = true
end
decorate_value(parms, first_unit, i+1, enable_number_word)
local show = valinfo[i+1].show
if add_unit then
show = show .. first_unit.sep .. (i == 0 and id1 or make_id(parms, i+1, first_unit))
end
if i == 0 then
result = show
else
result = range_text(range[i], want_name, parms, result, show, 'in')
end
end
else
decorate_value(parms, first_unit, 1, true)
result = valinfo[1].show
end
return result .. preunit .. extra
end
local function process_one_output(parms, out_current)
-- Processing required for each output unit.
-- Return block of text to represent output (value/unit).
local inout = out_current.inout -- normally 'out' but can be 'in' for order=out
local id1, want_name = make_id(parms, 1, out_current)
local sep = out_current.sep -- set by make_id
local preunit = parms.preunit2
if preunit then
sep = '' -- any separator is included in preunit
else
preunit = ''
end
if parms.opt_output_unit_only then
if want_name and parms.opt_adjectival then
return preunit .. hyphenated(id1)
end
return preunit .. id1
end
if out_current.builtin == 'mach' and out_current.sep ~= '' then -- '' means omitsep with non-enwiki name
local prefix = id1 .. ' '
local range = parms.range
local valinfo = out_current.valinfo
local result = prefix .. valinfo[1].show
if range then
-- For simplicity and because more not needed, handle one range item only.
result = range_text(range[1], want_name, parms, result, prefix .. valinfo[2].show, inout, {spaced=true})
end
return preunit .. result
end
local add_unit = (parms[parms.opt_flip and 'in_range_x' or 'out_range_x'] or
(not want_name and parms.abbr_range_x)) and
not parms.opt_output_number_only
local range = parms.range
if range and not add_unit then
unlink(out_current)
end
local id = range and make_id(parms, range.n + 1, out_current) or id1
local extra, was_hyphenated = hyphenated_maybe(parms, want_name, sep, id, inout)
if was_hyphenated then
add_unit = false
end
local result
local valinfo = out_current.valinfo
if range then
for i = 0, range.n do
local enable_number_word
if i == range.n then
add_unit = false
enable_number_word = true
end
decorate_value(parms, out_current, i+1, enable_number_word)
local show = valinfo[i+1].show
if add_unit then
show = show .. out_current.sep .. (i == 0 and id1 or make_id(parms, i+1, out_current))
end
if i == 0 then
result = show
else
result = range_text(range[i], want_name, parms, result, show, inout)
end
end
else
decorate_value(parms, out_current, 1, true)
result = valinfo[1].show
end
if parms.opt_output_number_only then
return result
end
return result .. preunit .. extra
end
local function make_output_single(parms, in_unit_table, out_unit_table)
-- Return true, item where item = wikitext of the conversion result
-- for a single output (which is not a combination or a multiple);
-- or return false, t where t is an error message table.
if parms.opt_order_out and in_unit_table.unitcode == out_unit_table.unitcode then
out_unit_table.valinfo = in_unit_table.valinfo
else
out_unit_table.valinfo = collection()
for _, v in ipairs(in_unit_table.valinfo) do
local success, info = cvtround(parms, v, in_unit_table, out_unit_table)
if not success then return false, info end
out_unit_table.valinfo:add(info)
end
end
return true, process_one_output(parms, out_unit_table)
end
local function make_output_multiple(parms, in_unit_table, out_unit_table)
-- Return true, item where item = wikitext of the conversion result
-- for an output which is a multiple (like 'ftin');
-- or return false, t where t is an error message table.
local inout = out_unit_table.inout -- normally 'out' but can be 'in' for order=out
local multiple = out_unit_table.multiple -- table of scaling factors (will not be nil)
local combos = out_unit_table.combination -- table of unit tables (will not be nil)
local abbr = parms.abbr
local abbr_org = parms.abbr_org
local disp = parms.disp
local want_name = (abbr_org == nil and (disp == 'or' or disp == 'slash')) or
not (abbr == 'on' or abbr == inout or abbr == 'mos')
local want_link = (parms.lk == 'on' or parms.lk == inout)
local mid = parms.opt_flip and parms.mid or ''
local sep1 = ' '
local sep2 = ' '
if parms.opt_adjectival and want_name then
sep1 = '-'
sep2 = '-'
end
local do_spell = parms.opt_spell_out
parms.opt_spell_out = nil -- so the call to cvtround does not spell the value
local function make_result(info, isfirst)
local fmt, outvalue, sign
local results = {}
for i = 1, #combos do
local tfrac, thisvalue, strforce
local out_current = combos[i]
out_current.inout = inout
local scale = multiple[i]
if i == 1 then -- least significant unit ('in' from 'ftin')
local decimals
out_current.frac = out_unit_table.frac
local success, outinfo = cvtround(parms, info, in_unit_table, out_current)
if not success then return false, outinfo end
if isfirst then
out_unit_table.valinfo = { outinfo } -- in case output value of first least significant unit is needed
end
sign = outinfo.sign
tfrac = outinfo.fraction_table
if outinfo.is_scientific then
strforce = outinfo.show
decimals = ''
elseif tfrac then
decimals = ''
else
local show = outinfo.show -- number as a string in local language
local p1, p2 = show:find(numdot, 1, true)
decimals = p1 and show:sub(p2 + 1) or '' -- text after numdot, if any
end
fmt = '%.' .. ulen(decimals) .. 'f' -- to reproduce precision
if decimals == '' then
if tfrac then
outvalue = floor(outinfo.raw_absvalue) -- integer part only; fraction added later
else
outvalue = floor(outinfo.raw_absvalue + 0.5) -- keep all integer digits of least significant unit
end
else
outvalue = outinfo.absvalue
end
end
if scale then
outvalue, thisvalue = divide(outvalue, scale)
else
thisvalue = outvalue
end
local id
if want_name then
if varname then
local clean
if strforce or tfrac then
clean = '.1' -- dummy value to force name for floating point
else
clean = format(fmt, thisvalue)
end
id = variable_name(clean, out_current)
else
local key = 'name2'
if parms.opt_adjectival then
key = 'name1'
elseif tfrac then
if thisvalue == 0 then
key = 'name1'
end
elseif parms.opt_singular then
if 0 < thisvalue and thisvalue < 1.0001 then
key = 'name1'
end
else
if thisvalue == 1 then
key = 'name1'
end
end
id = out_current[key]
end
else
id = out_current['symbol']
end
if i == 1 and omit_separator(id) then
-- Testing the id of the least significant unit should be sufficient.
sep1 = ''
sep2 = ''
end
if want_link then
local link = out_current.link
if link then
id = make_link(link, id, out_current)
end
end
local strval
local spell_inout = (i == #combos or outvalue == 0) and inout or '' -- trick so the last value processed (first displayed) has uppercase, if requested
if strforce and outvalue == 0 then
sign = '' -- any sign is in strforce
strval = strforce -- show small values in scientific notation; will only use least significant unit
elseif tfrac then
local wholestr = (thisvalue > 0) and tostring(thisvalue) or nil
strval = format_fraction(parms, spell_inout, false, wholestr, tfrac.numstr, tfrac.denstr, do_spell)
else
strval = (thisvalue == 0) and from_en('0') or with_separator(parms, format(fmt, thisvalue))
if do_spell then
strval = spell_number(parms, spell_inout, strval) or strval
end
end
table.insert(results, strval .. sep1 .. id)
if outvalue == 0 then
break
end
fmt = '%.0f' -- only least significant unit can have a non-integral value
end
local reversed, count = {}, #results
for i = 1, count do
reversed[i] = results[count + 1 - i]
end
return true, sign .. table.concat(reversed, sep2)
end
local valinfo = in_unit_table.valinfo
local success, result = make_result(valinfo[1], true)
if not success then return false, result end
local range = parms.range
if range then
for i = 1, range.n do
local success, result2 = make_result(valinfo[i+1])
if not success then return false, result2 end
result = range_text(range[i], want_name, parms, result, result2, inout, {spaced=true})
end
end
return true, result .. mid
end
local function process(parms, in_unit_table, out_unit_table)
-- Return true, s, outunit where s = final wikitext result,
-- or return false, t where t is an error message table.
linked_pages = {}
local success, bad_output
local bad_input_mcode = in_unit_table.bad_mcode -- nil if input unit is a valid convert unit
local out_unit = parms.out_unit
if out_unit == nil or out_unit == '' or type(out_unit) == 'function' then
-- out_unit can be set to a function by adjustparameters in Module:Convert/wikidata.
if bad_input_mcode or parms.opt_input_unit_only then
bad_output = ''
else
local getdef = type(out_unit) == 'function' and out_unit or get_default
success, out_unit = getdef(in_unit_table.valinfo[1].value, in_unit_table)
parms.out_unit = out_unit
if not success then
bad_output = out_unit
end
end
end
if not bad_output and not out_unit_table then
success, out_unit_table = lookup(parms, out_unit, 'any_combination')
if success then
local mismatch = check_mismatch(in_unit_table, out_unit_table)
if mismatch then
bad_output = mismatch
end
else
bad_output = out_unit_table
end
end
local lhs, rhs
local flipped = parms.opt_flip and not bad_input_mcode
if bad_output then
rhs = (bad_output == '') and '' or message(parms, bad_output)
elseif parms.opt_input_unit_only then
rhs = ''
else
local combos -- nil (for 'ft' or 'ftin'), or table of unit tables (for 'm ft')
if not out_unit_table.multiple then -- nil/false ('ft' or 'm ft'), or table of factors ('ftin')
combos = out_unit_table.combination
end
local frac = parms.frac -- nil or denominator of fraction for output values
if frac then
-- Apply fraction to the unit (if only one), or to non-SI units (if a combination),
-- except that if a precision is also specified, the fraction only applies to
-- the hand unit; that allows the following result:
-- {{convert|156|cm|in hand|1|frac=2}} → 156 centimetres (61.4 in; 15.1½ hands)
-- However, the following is handled elsewhere as a special case:
-- {{convert|156|cm|hand in|1|frac=2}} → 156 centimetres (15.1½ hands; 61½ in)
if combos then
local precision = parms.precision
for _, unit in ipairs(combos) do
if unit.builtin == 'hand' or (not precision and not unit.prefixes) then
unit.frac = frac
end
end
else
out_unit_table.frac = frac
end
end
local outputs = {}
local imax = combos and #combos or 1 -- 1 (single unit) or number of unit tables
if imax == 1 then
parms.opt_order_out = nil -- only useful with an output combination
end
if not flipped and not parms.opt_order_out then
-- Process left side first so any duplicate links (from lk=on) are suppressed
-- on right. Example: {{convert|28|e9pc|e9ly|abbr=off|lk=on}}
lhs = process_input(parms, in_unit_table)
end
for i = 1, imax do
local success, item
local out_current = combos and combos[i] or out_unit_table
out_current.inout = 'out'
if i == 1 then
if imax > 1 and out_current.builtin == 'hand' then
out_current.out_next = combos[2] -- built-in hand can influence next unit in a combination
end
if parms.opt_order_out then
out_current.inout = 'in'
end
end
if out_current.multiple then
success, item = make_output_multiple(parms, in_unit_table, out_current)
else
success, item = make_output_single(parms, in_unit_table, out_current)
end
if not success then return false, item end
outputs[i] = item
end
if parms.opt_order_out then
lhs = outputs[1]
table.remove(outputs, 1)
end
local sep = parms.table_joins and parms.table_joins[2] or parms.join_between
rhs = table.concat(outputs, sep)
end
if flipped or not lhs then
local input = process_input(parms, in_unit_table)
if flipped then
lhs = rhs
rhs = input
else
lhs = input
end
end
if parms.join_before then
lhs = parms.join_before .. lhs
end
local wikitext
if bad_input_mcode then
if bad_input_mcode == '' then
wikitext = lhs
else
wikitext = lhs .. message(parms, bad_input_mcode)
end
elseif parms.table_joins then
wikitext = parms.table_joins[1] .. lhs .. parms.table_joins[2] .. rhs
else
wikitext = lhs .. parms.joins[1] .. rhs .. parms.joins[2]
end
if parms.warnings and not bad_input_mcode then
wikitext = wikitext .. parms.warnings
end
return true, get_styles(parms) .. wikitext, out_unit_table
end
local function _main_convert(confArgs, parmsArgs, frame)
-- Do convert, and if needed, do it again with higher default precision.
local parms = { frame = frame or mw.getCurrentFrame() } -- will hold template arguments, after translation
set_config(confArgs)
local success, result = get_parms(parms, parmsArgs)
if success then
if type(result) ~= 'table' then
return tostring(result)
end
local in_unit_table = result
local out_unit_table
for _ = 1, 2 do -- use counter so cannot get stuck repeating convert
success, result, out_unit_table = process(parms, in_unit_table, out_unit_table)
if success and parms.do_convert_again then
parms.do_convert_again = false
else
break
end
end
end
-- If input=x gives a problem, the result should be just the user input
-- (if x is a property like P123 it has been replaced with '').
-- An unknown input unit would display the input and an error message
-- with success == true at this point.
-- Also, can have success == false with a message that outputs an empty string.
if parms.input_text then
if success and not parms.have_problem then
return result
end
local cat
if parms.tracking then
-- Add a tracking category using the given text as the category sort key.
-- There is currently only one type of tracking, but in principle multiple
-- items could be tracked, using different sort keys for convenience.
cat = wanted_category('tracking', parms.tracking)
end
return parms.input_text .. (cat or '')
end
return success and result or message(parms, result)
end
local function main_convert(frame)
return _main_convert(frame.args, frame:getParent().args, frame)
end
local function _unit(unitcode, options)
-- Helper function for Module:Val to look up a unit.
-- Parameter unitcode must be a string to identify the wanted unit.
-- Parameter options must be nil or a table with optional fields:
-- value = number (for sort key; default value is 1)
-- scaled_top = nil for a normal unit, or a number for a unit which is
-- the denominator of a per unit (for sort key)
-- si = { 'symbol', 'link' }
-- (a table with two strings) to make an SI unit
-- that will be used for the look up
-- link = true if result should be [[linked]]
-- sort = 'on' or 'debug' if result should include a sort key in a
-- span element ('debug' makes the key visible)
-- name = true for the name of the unit instead of the symbol
-- us = true for the US spelling of the unit, if any
-- Return nil if unitcode is not a non-empty string.
-- Otherwise return a table with fields:
-- text = requested symbol or name of unit, optionally linked
-- scaled_value = input value adjusted by unit scale; used for sort key
-- sortspan = span element with sort key like that provided by {{ntsh}},
-- calculated from the result of converting value
-- to a base unit with scale 1.
-- unknown = true if the unitcode was not known
unitcode = strip(unitcode)
if unitcode == nil or unitcode == '' then
return nil
end
set_config({})
linked_pages = {}
options = options or {}
local parms = {
abbr = options.name and 'off' or 'on',
lk = options.link and 'on' or nil,
opt_sp_us = options.us and true or nil,
opt_ignore_error = true, -- do not add pages using this function to 'what links here' for Module:Convert/extra
opt_sortable_on = options.sort == 'on' or options.sort == 'debug',
opt_sortable_debug = options.sort == 'debug',
}
if options.si then
-- Make a dummy table of units (just one unit) for lookup to use.
-- This makes lookup recognize any SI prefix in the unitcode.
local symbol = options.si[1] or '?'
parms.unittable = { [symbol] = {
_name1 = symbol,
_name2 = symbol,
_symbol = symbol,
utype = symbol,
scale = symbol == 'g' and 0.001 or 1,
prefixes = 1,
default = symbol,
link = options.si[2],
}}
end
local success, unit_table = lookup(parms, unitcode, 'no_combination')
if not success then
unit_table = setmetatable({
symbol = unitcode, name2 = unitcode, utype = unitcode,
scale = 1, default = '', defkey = '', linkey = '' }, unit_mt)
end
local value = tonumber(options.value) or 1
local clean = tostring(abs(value))
local info = {
value = value,
altvalue = value,
singular = (clean == '1'),
clean = clean,
show = clean,
}
unit_table.inout = 'in'
unit_table.valinfo = { info }
local sortspan, scaled_value
if options.sort then
sortspan, scaled_value = make_table_or_sort(parms, value, info, unit_table, options.scaled_top)
end
return {
text = make_id(parms, 1, unit_table),
sortspan = sortspan,
scaled_value = scaled_value,
unknown = not success and true or nil,
}
end
return { convert = main_convert, _convert = _main_convert, _unit = _unit }
84ef1800df9ddbc24da3d295d74282d1c59ec2b5
Captain Yulia
0
742
1144
2025-08-06T13:05:28Z
Sharparam
284703
Redirected page to [[Royal Division Captain Yulia]]
wikitext
text/x-wiki
#REDIRECT [[Royal Division Captain Yulia]]
944a6e86bec704d704b6109fc690822aa40d60b9
Vermillion Mirage
0
753
1166
2025-08-06T13:05:55Z
Sharparam
284703
Redirected page to [[Royal Division Captain Yulia & Vermillion Mirage]]
wikitext
text/x-wiki
#REDIRECT [[Royal Division Captain Yulia & Vermillion Mirage]]
a706f52584d29641b5b3d4ebd9403828f396a0e3
Royal Division Captain Yulia & Vermillion Mirage
0
551
862
2025-08-06T13:16:49Z
Sharparam
284703
Update entropy gain description
wikitext
text/x-wiki
{{Infobox/Boss
| image = Final boss.png
}}
'''{{PAGENAME}}''' is the final [[Bosses|boss]] in {{BFF}}.
== Overview ==
When starting the fight, only the [[Vermillion Mirage]] will be present, including showing only its name in the boss healthbar.
After the mirage takes a certain amount of damage, [[Royal Division Captain Yulia]] will join the fight, updating the name in the boss healthbar to include both of them.
Dying for any reason after Yulia joins the fight causes the player to gain 0.5% [[entropy]]. This is because the act of her joining applies a debuff to the player causing entropy gain on death.
Throughout the fight, they will take turns being the active enemy, with the other one falling back to take a more passive role and using various ranged abilities on the player.
Defeating the boss will immediately trigger the [[Endings|ending]] cutscene.
After getting back to the title screen, the save file can be loaded again which will put the player at the same homunculus, allowing for the boss to be fought again. This makes it the only boss in the game that can be fought multiple times without having to start a new game.
== Location ==
Found at the end of [[Vermillion Fields]]. At the final location of the "Temple" [[Homunculus]], head up the large stairs and the boss arena will be at the top.
{{Navbox/Bosses}}
[[Category:Pages that need coordinates]]
dfff03fcfd660a270e379514af4cb192c6e3d589
Entropy
0
709
1084
2025-08-06T13:17:41Z
Sharparam
284703
Update description for final boss
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a property of the player in {{BFF}}.
== Overview ==
Entropy can only be gained from a few sources.
* Dying to a [[Vermillion Knight]] increases entropy by 0.25%.
* Dying during phase 2 of the [[Royal Division Captain Yulia & Vermillion Mirage]] boss fight (after Yulia joins the fight) increases entropy by 0.5%.
Upon reaching 100% entropy, the player's save file is deleted.
[[Category:Game mechanics]]
cda5c4f1fca74bd5447670462ba15ebe07df0b38
Template:Infobox/Weapon
10
451
666
2025-08-19T02:14:26Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| ranged = [[Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
6ed81445f4e99c129429ea030ff07667c32cc439
Main Page
0
1
1
2025-08-20T01:22:19Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Bleak Faith: Forsaken Wiki]]
cbeda71f0e01355547a440cf49c164ea0bce9014
2
1
2025-08-20T01:22:20Z
ARTIFICER
564804
Protected "[[Main Page]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
#redirect [[Bleak Faith: Forsaken Wiki]]
cbeda71f0e01355547a440cf49c164ea0bce9014
Bleak Faith: Forsaken Wiki
0
2
3
2025-08-20T01:22:20Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<!-- Hello and welcome to wiki.gg! This page is built via our IMProved Main Page (IMP) framework. If you are familiar with CSS grid areas, that's what you're defining here! But if you don't know any CSS that's ok!
👀 RULE 1: the same keyword represents the same section & can span multiple cells
👀 RULE 2: Each box in each layout must be a CONTIGUOUS RECTANGLE of any dimensions (most likely one of: 1x1, 1x2, 2x1, 2x2, 1x3, 3x1, 3x2, 2x3)
👀 RULE 3: This page defines LAYOUT ONLY. To edit the content, please use the links provided for you after saving/previewing your page.
👀 RULE 4: If you want to RENAME or ADD a box, (1) add a new section to the grid layout below (all three breakpoints!) and then (2) save or preview this page and then (3) click "Create this box"
-->{{Main page
|desktop=
<!-- for WIDE SCREENS -->
<!-- 👀 keep this at 3 columns, but you can otherwise rearrange as desired -->
welcome welcome welcome
about pages pages
contribute contribute external
<!-- end WIDE SCREEN layout -->
|tablet=
<!-- for TABLET SCREENS -->
<!-- 👀 keep this at 2 columns, but you can otherwise rearrange as desired -->
welcome welcome
about pages
contribute external
<!-- end TABLET SCREEN layout -->
|mobile=
<!-- for MOBILE DEVICES -->
<!-- 👀 keep this at 1 column, but you can otherwise rearrange as desired -->
welcome
about
pages
external
contribute
<!-- end MOBILE DEVICE layout -->
}}
{{#description2:Welcome to the {{SITENAME}}, a collaborative wiki resource that is open for anyone to edit!}} <!-- this is a short description of your wiki, which will appear in embeds in Google search results, Discord links, etc. -->
c5d4351377806d884e84bc34774f85fd4a425e0a
4
3
2025-08-20T01:22:21Z
ARTIFICER
564804
Protected "[[Bleak Faith: Forsaken Wiki]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<!-- Hello and welcome to wiki.gg! This page is built via our IMProved Main Page (IMP) framework. If you are familiar with CSS grid areas, that's what you're defining here! But if you don't know any CSS that's ok!
👀 RULE 1: the same keyword represents the same section & can span multiple cells
👀 RULE 2: Each box in each layout must be a CONTIGUOUS RECTANGLE of any dimensions (most likely one of: 1x1, 1x2, 2x1, 2x2, 1x3, 3x1, 3x2, 2x3)
👀 RULE 3: This page defines LAYOUT ONLY. To edit the content, please use the links provided for you after saving/previewing your page.
👀 RULE 4: If you want to RENAME or ADD a box, (1) add a new section to the grid layout below (all three breakpoints!) and then (2) save or preview this page and then (3) click "Create this box"
-->{{Main page
|desktop=
<!-- for WIDE SCREENS -->
<!-- 👀 keep this at 3 columns, but you can otherwise rearrange as desired -->
welcome welcome welcome
about pages pages
contribute contribute external
<!-- end WIDE SCREEN layout -->
|tablet=
<!-- for TABLET SCREENS -->
<!-- 👀 keep this at 2 columns, but you can otherwise rearrange as desired -->
welcome welcome
about pages
contribute external
<!-- end TABLET SCREEN layout -->
|mobile=
<!-- for MOBILE DEVICES -->
<!-- 👀 keep this at 1 column, but you can otherwise rearrange as desired -->
welcome
about
pages
external
contribute
<!-- end MOBILE DEVICE layout -->
}}
{{#description2:Welcome to the {{SITENAME}}, a collaborative wiki resource that is open for anyone to edit!}} <!-- this is a short description of your wiki, which will appear in embeds in Google search results, Discord links, etc. -->
c5d4351377806d884e84bc34774f85fd4a425e0a
Bleak Faith: Forsaken Wiki/welcome
0
4
6
2025-08-20T01:22:22Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = Welcome to the {{SITENAME}}!
}}
We are currently maintaining [[Special:AllPages|{{NUMBEROFARTICLES}} articles]]. Please feel free to contribute by creating new articles or expanding existing ones.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
96df981ef23fca9434d1586228cab8a51e0fdc0a
7
6
2025-08-20T01:22:22Z
ARTIFICER
564804
Protected "[[Bleak Faith: Forsaken Wiki/welcome]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
{{Main page box/start
| title = Welcome to the {{SITENAME}}!
}}
We are currently maintaining [[Special:AllPages|{{NUMBEROFARTICLES}} articles]]. Please feel free to contribute by creating new articles or expanding existing ones.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
96df981ef23fca9434d1586228cab8a51e0fdc0a
Bleak Faith: Forsaken Wiki/pages
0
5
8
2025-08-20T01:22:22Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = Useful wiki pages
| class = centered-content
}}
<div class="mp-links columns-2">
* {{MP link|Important page here|image=Wiki.gg logo-pink.svg|size=92px}}
* {{MP link|Random page|link=Special:Random}}
* {{MP link|Example character|link=Example character|image=Example_character_image.png|size=92px}}
* {{MP link|Example character infobox|link=Template:Example character infobox|image=Example_character_image.png|size=92px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
827f14b4cd3d346ca427f95e9574fc23c4874206
9
8
2025-08-20T01:22:23Z
ARTIFICER
564804
Protected "[[Bleak Faith: Forsaken Wiki/pages]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
{{Main page box/start
| title = Useful wiki pages
| class = centered-content
}}
<div class="mp-links columns-2">
* {{MP link|Important page here|image=Wiki.gg logo-pink.svg|size=92px}}
* {{MP link|Random page|link=Special:Random}}
* {{MP link|Example character|link=Example character|image=Example_character_image.png|size=92px}}
* {{MP link|Example character infobox|link=Template:Example character infobox|image=Example_character_image.png|size=92px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
827f14b4cd3d346ca427f95e9574fc23c4874206
Bleak Faith: Forsaken Wiki/about
0
6
10
2025-08-20T01:22:23Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = About Bleak Faith: Forsaken
}}
This is an example main page. You can redesign it however you want, or you can keep the layout the same but change the contents (e.g. this part should talk about your game). Take a look at some other wiki.gg wikis for inspiration!
<div style="text-align:right">[[Bleak Faith: Forsaken|Read more...]]</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
d5a0888496afa538312e1253db527add7089b342
11
10
2025-08-20T01:22:24Z
ARTIFICER
564804
Protected "[[Bleak Faith: Forsaken Wiki/about]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
{{Main page box/start
| title = About Bleak Faith: Forsaken
}}
This is an example main page. You can redesign it however you want, or you can keep the layout the same but change the contents (e.g. this part should talk about your game). Take a look at some other wiki.gg wikis for inspiration!
<div style="text-align:right">[[Bleak Faith: Forsaken|Read more...]]</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
d5a0888496afa538312e1253db527add7089b342
Bleak Faith: Forsaken Wiki/contribute
0
7
12
2025-08-20T01:22:24Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = Contribute to the wiki
}}
{{SITENAME}} is a collaborative wiki resource that is open for anyone to edit. You don't need special permission beyond [[Special:UserLogin/signup|registering]] an account to edit most pages, and your contributions can grow the wiki and help other players.
; Adding content
:* If you are unsure of what to do or how to create a page, search for a few articles on the same topic and see what they look like. You can always view the source code in a wiki and learn from what others have done.
:* An edit doesn't have to be massive; if you feel you don't want to create whole articles, then just fixing spelling errors and broken links is enough.
:* [[Special:UserLogin/signup|Register]] to edit and track your contributions.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
8b79debc73480ec2b12cb5e39723b94532fd44bd
13
12
2025-08-20T01:22:24Z
ARTIFICER
564804
Protected "[[Bleak Faith: Forsaken Wiki/contribute]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
{{Main page box/start
| title = Contribute to the wiki
}}
{{SITENAME}} is a collaborative wiki resource that is open for anyone to edit. You don't need special permission beyond [[Special:UserLogin/signup|registering]] an account to edit most pages, and your contributions can grow the wiki and help other players.
; Adding content
:* If you are unsure of what to do or how to create a page, search for a few articles on the same topic and see what they look like. You can always view the source code in a wiki and learn from what others have done.
:* An edit doesn't have to be massive; if you feel you don't want to create whole articles, then just fixing spelling errors and broken links is enough.
:* [[Special:UserLogin/signup|Register]] to edit and track your contributions.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
8b79debc73480ec2b12cb5e39723b94532fd44bd
Bleak Faith: Forsaken Wiki/external
0
8
14
2025-08-20T01:22:24Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = External links
}}
<div class="mp-links columns-2">
* {{MP link|Official site|link=https://wiki.gg}}
* {{MP link|Discord|link=https://discord.gg/rTnST57tuW|image=Discord.svg|size=64x64px}}
* {{MP link|Bluesky|link=https://bsky.app/profile/wiki.gg|image=Bluesky.svg|size=64x64px}}
* {{MP link|indie.io|link=https://www.indie.io/|image=indie.io.svg|size=64x64px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
bb8190c57bb4cc147764d1c10f218fe4d34e0a49
15
14
2025-08-20T01:22:25Z
ARTIFICER
564804
Protected "[[Bleak Faith: Forsaken Wiki/external]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
{{Main page box/start
| title = External links
}}
<div class="mp-links columns-2">
* {{MP link|Official site|link=https://wiki.gg}}
* {{MP link|Discord|link=https://discord.gg/rTnST57tuW|image=Discord.svg|size=64x64px}}
* {{MP link|Bluesky|link=https://bsky.app/profile/wiki.gg|image=Bluesky.svg|size=64x64px}}
* {{MP link|indie.io|link=https://www.indie.io/|image=indie.io.svg|size=64x64px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
bb8190c57bb4cc147764d1c10f218fe4d34e0a49
Meta:Default Loadout Wiki:Copyrights
4
9
16
2025-08-20T01:22:26Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<!--''[[GAME]]'' content and materials are the intellectual property of their respective owners.
-->Content that you make available on {{SITENAME}} is licensed by you to us under our [{{int:wikigg-tos-url}} Terms of Service]. Do not make content available on {{SITENAME}} where you do not have the necessary rights to grant this license.
All textual and graphical content on {{SITENAME}} that we may lawfully license is licensed to you under the [https://creativecommons.org/licenses/by-sa/4.0 Creative Commons Attribution-ShareAlike 4.0] license.
[[Category:Legal notices]]
a5c705cf276359aef94d426ee75d18bbf1e361ac
17
16
2025-08-20T01:22:26Z
ARTIFICER
564804
Protected "[[Meta:Default Loadout Wiki:Copyrights]]" ([Edit=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<!--''[[GAME]]'' content and materials are the intellectual property of their respective owners.
-->Content that you make available on {{SITENAME}} is licensed by you to us under our [{{int:wikigg-tos-url}} Terms of Service]. Do not make content available on {{SITENAME}} where you do not have the necessary rights to grant this license.
All textual and graphical content on {{SITENAME}} that we may lawfully license is licensed to you under the [https://creativecommons.org/licenses/by-sa/4.0 Creative Commons Attribution-ShareAlike 4.0] license.
[[Category:Legal notices]]
a5c705cf276359aef94d426ee75d18bbf1e361ac
Module:Infobox
828
10
18
2025-08-20T01:22:26Z
ARTIFICER
564804
Importing default loadout
Scribunto
text/plain
-- version 0.1.7
--------------------------------------
-- User settings, you can modify these
--------------------------------------
-- if you want to not always use divs in your wiki (as opposed to tables), you can change this default
-- just remember to change it back each time you update from the main "branch" on the support wiki!
-- you can also control it per infobox with `|useDivs=yes` or `|useDivs=no`
local USE_DIVS = true -- `false` or `true`
-- default value to show if a param is missing in some but not all tabs.
-- set to `nil` (not in quotes) to remove such rows altogether in the tabs where they're missing
local TABBED_NONEXIST = nil -- `''` or `nil` or `'N/A'` etc. Don't put nil in quotes.
---------------------------------------------------------------------------
-- Do not modify anything below this line unless you know what you're doing
---------------------------------------------------------------------------
local h = {}
local p = {}
local hooks = {}
function p.arraymap(frame)
-- a lua implementation of Page Forms' arraymap
local args = h.overwrite()
local items = h.split(args[1], args[2] or ',')
for i, item in ipairs(items) do
items[i] = args[4]:gsub(args[3], item)
end
return table.concat(items, args[5] or ',')
end
function p.preprocess(frame)
return frame:preprocess(frame.args[1] or frame:getParent().args[1])
end
function p.main(frame)
h.registerHooks()
h.increment()
local args = h.overwrite()
local sep = args.sep or ','
h.castArgs(args, sep)
if h.castBool(args.setmainimage or 'yes') then
h.setMainImage(args.images[1])
end
-- suggest to use HIDDENCAT here; will be used for maintenance & gadget imports
return h.makeInfobox(args, sep), '[[Category:Pages with DRUID infoboxes]]'
end
function h.registerHooks()
if not mw.title.new('Module:Infobox/Hooks').exists then return end
hooks = require('Module:Infobox/Hooks')
end
function h.runHook(key, ...)
if hooks[key] then
hooks[key](...)
end
end
function h.increment()
-- optional use of VariablesLua for better compatibility
local VariablesLua = mw.ext.VariablesLua
if VariablesLua == nil then
local res
-- try to fall back to normal Variables
res, h.counter = pcall(
function()
return mw.getCurrentFrame():callParserFunction('#var', {'DRUID_INFOBOX_ID', 0}) + 1
end
)
if res then
mw.getCurrentFrame():callParserFunction('#vardefine', {'DRUID_INFOBOX_ID', h.counter})
else
-- else use a random number so at least there's some unique id
h.counter = math.random(100000000000000000) -- random integer
end
else
h.counter = VariablesLua.var('DRUID_INFOBOX_ID', 0) + 1
VariablesLua.vardefine('DRUID_INFOBOX_ID', h.counter)
end
end
function h.castArgs(args, sep)
h.runHook('onCastArgsStart', args, sep, args.kind)
args.tabs = h.split(args.tabs or args.image_labels, sep)
args.images = h.getImages(args, sep)
args.sections = h.split(args.sections, sep)
for _, section in ipairs(args.sections) do
if h.castBool(args[section .. '_isdata']) then
args[section .. 'Data'] = args[section]
args[section] = section .. 'Data'
args[section .. 'Data_nolabel'] = 'true' -- will be cast later
end
args[section] = h.split(args[section], sep)
args[section .. '_tabs'] = h.split(args[section .. '_tabs'], sep)
if #args.tabs > 0 and #args[section .. '_tabs'] > 0 then
error(('You cannot specify |tabs= and |%s= at the same time, please pick one'):format(section .. '_tabs'))
end
end
if args.useDivs then
USE_DIVS = h.castBool(args.useDivs)
end
-- this would be in the outer scope, but we're hiding it
h.entityType = USE_DIVS and 'div' or 'table' -- key of h.htmlEntities
h.runHook('onCastArgsEnd', args, sep, args.kind)
end
function h.getImages(args, sep)
if args.image and not args.images then
args.images = args.image
end
if args.images then
return h.split(args.images, sep)
end
if not args.tabs then return {} end
local ret = {}
for _, key in ipairs(args.tabs) do
if args[key .. '_image'] then
ret[#ret+1] = args[key .. '_image']
end
end
return ret
end
function h.setMainImage(file)
if h.counter > 1 then return end
if not file then return end
local fileText = file:gsub('.-:', '')
fileText = fileText:gsub('^([^|%]]+).*', '%1')
-- setmainimage is guaranteed to exist on wiki.gg but may not exist on other wikis
-- it's not a crucial piece of functionality so we'll fail silently if it doesn't exist
pcall(function() mw.getCurrentFrame():callParserFunction{
name = '#setmainimage',
args = { fileText },
} end)
end
function h.makeInfobox(args, sep)
local out = mw.html.create(h.getTag('container'))
:addClass('druid-infobox')
:addClass('druid-container')
:addClass('noexcerpt')
:addClass(args.class) -- warning: class can be nil, don't concat anything
:attr('id', args.id or ('druid-container-' .. h.counter))
h.runHook('onMakeOutputStart', out, args)
if args.kind then out:addClass('druid-container-' .. h.escape(args.kind)) end
h.printTitle(out, args)
h.printImages(out, args.images, args)
for _, section in ipairs(args.sections) do
-- cannot begin tagging here because we don't know if any applicable args are present
local cols = args[section .. '_columns']
local makeSection = cols and h.makeGridSection or h.makeSection
out:node(makeSection(section, args[section], args, tonumber(cols)))
end
h.runHook('onMakeOutputEnd', out, args)
-- category for gadget loading
return out, '[[Category:Pages with DRUID infoboxes]]'
end
function h.printTitle(out, args)
local tabs = args.tabs
if not tabs or #tabs == 0 then
h.printSimpleTitle(out, args)
return
end
if not h.hasComplexData('title', tabs, args) then
h.printSimpleTitle(out, args)
return
end
local node = h.printTitleWrapper(out)
h.printTabbedDataItem(node, 'title', tabs, args)
end
function h.printSimpleTitle(out, args)
if args.title then
local node = h.printTitleWrapper(out)
node:wikitext(args.title)
end
end
function h.printTitleWrapper(out)
return out:tag(h.getTag('titleOuter'))
:tag(h.getTag('titleInner'))
:addClass('druid-title')
:attr('colspan', 2)
end
function h.printTabbedDataItem(node, item, tabs, args)
-- hasData isn't used in the title case but we will need to track this
-- when we're printing section data later on
-- so we'll just track it always
local hasData = false
for i, label in ipairs(tabs) do
local div = node:tag('div')
:addClass('druid-toggleable-data')
:addClass('druid-toggleable')
:attr('data-druid', h.counter .. '-' .. i)
:attr('data-druid-tab-key', label)
if h.getTabbedContent(args, label, item) then
hasData = true
div:wikitext('\n\n' .. h.getTabbedContent(args, label, item))
div:addClass('druid-toggleable-data-nonempty')
else
div:addClass('druid-toggleable-data-empty')
end
if i == 1 then div:addClass('focused') end
end
return hasData
end
function h.printImages(out, images, args)
if #images == 0 and #args.tabs == 0 then return end
-- burden is on the user to format this as an image. this should be done in the infobox template,
-- with something like |image={{#if:{{{image|}}}|[[File:{{{image|}}}{{!}}300px{{!}}link=]]}}
local td = out:tag(h.getTag('section'))
:addClass('druid-section-container')
:tag(h.getTag('cell'))
:attr('colspan', 2)
local tabs = args.tabs
local tabTexts = h.getImageTabTexts(tabs, images, args)
h.printTabs(td, tabs, tabTexts, false, args)
if #images == 0 then return end
if #images == 1 then
td:addClass('druid-main-image')
:wikitext(images[1])
if args.caption then
td:tag('div')
:addClass('druid-main-image-caption')
:wikitext(args.caption)
end
return
end
td:addClass('druid-main-images')
local imagesContainer = td:tag('div')
:addClass('druid-main-images-files')
for i, image in ipairs(images) do
local container = imagesContainer:tag('div')
:addClass('druid-main-images-file')
:addClass('druid-toggleable')
:attr('data-druid', h.counter .. '-' .. i)
:wikitext(image)
:attr('data-druid-tab-key', tabs[i])
local labelText
if tabs[i] then
labelText = args[tabs[i] .. '_label'] or tabs[i]
else
labelText = '[[Category:Infoboxes missing image labels]]Image ' .. i
end
if args[labelText .. '_caption'] then
container:tag('div')
:addClass('druid-main-images-caption')
:wikitext(args[labelText .. '_caption'])
end
if i == 1 then
container:addClass('focused')
end
end
end
function h.getImageTabTexts(tabs, images, args)
if #tabs == 0 and #images <= 1 then return {} end
local texts = {}
local i = 1
while images[i] or tabs[i] do
if tabs[i] then
texts[i] = args[tabs[i] .. '_label'] or tabs[i]
else
texts[i] = '[[Category:Infoboxes missing image labels]]Image ' .. i
end
i = i + 1
end
return texts
end
function h.printTabs(td, tabs, texts, isSection, args)
if #texts == 0 then return end
local container = td:tag('div')
:addClass('druid-main-images-labels')
:addClass('druid-tabs')
if isSection then
container:addClass('druid-section-tabs')
end
for i, item in ipairs(tabs) do
local label = container:tag('div')
:addClass('druid-main-images-label')
:addClass('druid-tab')
:addClass('druid-toggleable')
:attr('data-druid', h.counter .. '-' .. i)
:wikitext(texts[i])
:attr('data-druid-tab-key', item)
if isSection then
label:addClass('druid-section-tab')
else
label:addClass('druid-title-tab')
end
if i == 1 then
label:addClass('focused')
end
-- this can be null, don't concat anything here
label:addClass(args[item .. '_class'])
end
end
function h.makeGridSection(section, sectionFields, args, numCols)
local numItems = h.countItems(sectionFields, section, args)
if numItems == 0 then return end
local node = mw.html.create(h.getTag('section'))
:addClass('druid-section-container')
h.printSectionHeader(node, section, args)
h.printSectionTabs(node, section, args)
local tr = node:tag(h.getTag('row'))
:attr('data-druid-section-row', h.escape(section))
if args[section .. '_collapsed'] then
tr:addClass('druid-collapsed')
end
local grid = tr:tag(h.getTag('cell'))
:attr('colspan', 2)
:addClass('druid-grid-section')
:addClass('druid-grid-section-' .. h.escape(section))
:addClass(args[section .. '_class']) -- warning: class can be nil, don't concat anything
:tag('div')
:addClass('druid-grid')
local row, col, i = 1, 1, 1
local sizeOfLastRow = numItems % numCols
local lcm = h.getNumGridCols(numItems, sizeOfLastRow, numCols)
grid:css('grid-template-columns', ('repeat(%s, 1fr)'):format(lcm))
local size = lcm / numCols
for _, item in ipairs(sectionFields) do
local node = mw.html.create('div')
local shouldPrint = h.printData(node, item, section, args)
if shouldPrint then
if i == numItems - sizeOfLastRow + 1 then
size = lcm / sizeOfLastRow
end
i = i + 1
local gStart = (col - 1) * size + 1
local gEnd = (col) * size + 1
local itemContainer = grid:tag('div')
:addClass('druid-grid-item')
:addClass('druid-grid-item-' .. h.escape(item))
:addClass(args[item .. '_class']) -- warning: class can be nil, don't concat anything
:css('grid-column', ('%s / %s'):format(gStart, gEnd))
:css('grid-row', row)
if not h.castBool(args[item .. '_nolabel']) then
h.printLabel(itemContainer:tag('div'), item, args)
end
itemContainer:node(node)
if col == numCols then
row = row + 1
col = 1
else
col = col + 1
end
end
end
return node
end
function h.makeSection(section, sectionFields, args)
if section == '' then return end -- bruteforce fix for trailing commas
local shouldPrint = false
local container = mw.html.create(h.getTag('section'))
:addClass('druid-section-container')
:addClass(args[section .. '_class']) -- warning: class can be nil, don't concat anything
h.printSectionHeader(container, section, args)
h.printSectionTabs(container, section, args)
for _, item in ipairs(sectionFields) do
local node = mw.html.create(h.getTag('cell'))
local shouldPrintItem = h.printData(node, item, section, args)
if shouldPrintItem then
shouldPrint = true
local tr = container:tag(h.getTag('row'))
:addClass('druid-row')
:addClass('druid-row-' .. h.escape(item))
:addClass(args[item .. '_class']) -- warning: class can be nil, don't concat anything
:attr('data-druid-section-row', h.escape(section))
if args[section .. '_collapsed'] then
tr:addClass('druid-collapsed')
end
if h.castBool(args[item .. '_wide']) or h.castBool(args[item .. '_nolabel']) then
node
:attr('colspan', 2)
:addClass('druid-data-wide')
else
h.printLabel(tr:tag(h.getTag('label')), item, args)
end
tr:node(node)
end
end
if not shouldPrint then return nil end
return container
end
function h.countItems(sectionFields, section, args)
local numItems = 0
for _, v in ipairs(sectionFields) do
-- we aren't actually printing here, but we're finding out if we should print anything
-- because we need the count of columns before we print anything in grid data
if h.printData(mw.html.create(), v, section, args) then
numItems = numItems + 1
end
end
return numItems
end
function h.getNumGridCols(numItems, sizeOfLastRow, numCols)
if not numCols then return numItems, 1 end
if numItems < numCols then return numItems, 1 end
if sizeOfLastRow == 0 then
return numCols, 1
end
local a, b = sizeOfLastRow, numCols
while b ~= 0 do
a, b = b, a % b
end
local lcm = sizeOfLastRow * numCols / a
return lcm
end
function h.printLabel(node, item, args)
return node
:addClass('druid-label')
:addClass('druid-label-' .. h.escape(item))
:wikitext(args[item .. '_display'] or args[item .. '_label'] or item)
end
function h.printData(node, item, section, args)
-- prints data to the node
-- and also returns whether the item is nonempty or not
local hasData = false
local sectionTabs = args[section .. '_tabs']
local tabs = args.tabs
if sectionTabs and #sectionTabs > 0 then
tabs = sectionTabs
end
if not tabs or #tabs == 0 then
return h.printSimpleData(node, item, args)
end
if not h.hasComplexData(item, tabs, args) then
return h.printSimpleData(node, item, args)
end
hasData = hasData or h.printTabbedDataItem(node, item, tabs, args)
if hasData then
node:addClass('druid-data')
end
return hasData
end
function h.getTabbedContent(args, label, item)
return args[label .. '_' .. item] or args[item] or TABBED_NONEXIST
end
function h.printSimpleData(node, item, args)
if args[item] and type(args[item]) ~= 'string' then
error(("Invalid use of field %s as both a section and a data value"):format(item))
end
if not args[item] then return false end
node:addClass('druid-data')
:addClass('druid-data-' .. h.escape(item))
:addClass('druid-data-nonempty')
:wikitext('\n\n' .. args[item])
return true
end
function h.hasComplexData(item, tabs, args)
for _, v in ipairs(tabs) do
if args[v .. '_' .. item] then return true end
end
return false
end
function h.printSectionHeader(node, section, args)
if h.castBool(args[section .. '_nolabel']) then return end
local tr = node:tag(h.getTag('row'))
:attr('data-druid-section', h.escape(section))
local th = tr:tag(h.getTag('sectionTitle'))
:attr('colspan', 2)
:addClass('druid-section')
:addClass('druid-section-' .. h.escape(section))
if args[section .. '_collapsible'] or args[section .. '_collapsed'] then
tr:addClass('druid-collapsible')
if args[section .. '_collapsed'] then
tr:addClass('druid-collapsible-collapsed')
end
end
local emptySections = {}
for _, label in ipairs(args.tabs) do
local hasLabel = false
for _, item in ipairs(args[section] or {}) do
if h.getTabbedContent(args, label, item) then
hasLabel = true
end
end
if not hasLabel then emptySections[label] = true end
end
if not next(emptySections) then
th:wikitext(args[section .. '_label'] or section)
return
end
for i, label in ipairs(args.tabs) do
local div = th:tag('div')
:addClass('druid-toggleable-heading')
:addClass('druid-toggleable')
:attr('data-druid', h.counter .. '-' .. i)
:wikitext(args[section .. '_label'] or section)
-- we are going to print the section content even in empty nodes
-- for compatibility with browsers without :has, where hiding empty rows won't happen
if emptySections[label] then
div:addClass('druid-toggleable-heading-empty')
end
if i == 1 then
div:addClass('focused')
end
end
end
function h.printSectionTabs(node, section, args)
local tabs = args[section .. '_tabs']
if not tabs or #tabs == 0 then return end
local tr = node:tag(h.getTag('sectionTabsOuter'))
:attr('data-druid-section', h.escape(section))
local th = tr:tag(h.getTag('sectionTabs'))
:attr('colspan', 2)
:addClass('druid-section-tabs')
:addClass('druid-section-tabs-' .. h.escape(section))
local texts = {}
for i, item in ipairs(tabs) do
texts[i] = args[item .. '_label'] or item
end
h.printTabs(th, tabs, texts, true, args)
end
----------------------------
-- general utility functions
----------------------------
function h.overwrite()
-- this is a generic utility function that collects args from the invoke call & the parent template.
-- normally, you merge args with parent template overwriting the invoke call, but
-- since we'll be putting markup/formatting into our invoke call,
-- we actually want to overwrite what the user sent.
local f = mw.getCurrentFrame()
local origArgs = f.args
local parentArgs = f:getParent().args
local args = {}
for k, v in pairs(parentArgs) do
v = mw.text.trim(v)
if v ~= '' then
args[k] = v
end
end
for k, v in pairs(origArgs) do
v = mw.text.trim(tostring(v))
if v ~= '' then
args[k] = v
end
end
return args
end
-- generic utility functions
-- these would normally be provided by other modules, but to make installation easy
-- I'm including everything here
function h.split(text, pattern, plain)
if not text then
return {}
end
local ret = {}
for m in h.gsplit(text, pattern, plain) do
ret[#ret+1] = m
end
return ret
end
function h.gsplit( text, pattern, plain )
if not pattern then pattern = ',' end
if not plain then
pattern = '%s*' .. pattern .. '%s*'
end
local s, l = 1, text:len()
return function ()
if s then
local e, n = text:find( pattern, s, plain )
local ret
if not e then
ret = text:sub( s )
s = nil
elseif n < e then
-- Empty separator!
ret = text:sub( s, e )
if e < l then
s = e + 1
else
s = nil
end
else
ret = e > s and text:sub( s, e - 1 ) or ''
s = n + 1
end
return ret
end
end, nil, nil
end
function h.escape(s)
s = s:gsub(' ', '')
:gsub('"', '')
:gsub("'", '')
:gsub("%?", '')
:gsub("%%", '')
:gsub("%[", '')
:gsub("%]", '')
:gsub("{", '')
:gsub("}", '')
:gsub("!", '')
return s
end
-- normally I would make these constants at the top of the file
-- but I don't want to mistake them with user-set constants
h.boolFalse = { ['false'] = true, ['no'] = true, [''] = true, ['0'] = true, ['nil'] = true }
function h.castBool(x)
if not x then return false end
return not h.boolFalse[tostring(x):lower()]
end
h.htmlEntities = {
table = {
container = 'table',
titleOuter = 'tr',
titleInner = 'th',
section = '',
sectionTitle = 'th',
sectionTabsOuter = 'tr',
sectionTabs = 'td',
row = 'tr',
label = 'th',
cell = 'td',
},
div = {
container = 'div',
titleOuter = 'div',
titleInner = 'div',
section = 'div',
sectionTitle = 'div',
sectionTabsOuter = 'div',
sectionTabs = 'div',
row = 'div',
label = 'div',
cell = 'div',
}
}
function h.getTag(key)
-- try not to totally fail here
return h.htmlEntities[h.entityType or 'div'][key]
end
return p
0b872baa88950499ed588906ea3b07f363640076
Module:Infobox/doc
828
11
19
2025-08-20T01:22:27Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{luadoc}}
This module enables the creation of [[support:DRUID infoboxes|DRUID infoboxes]].
0ce687b29fc5e2d6cad14853a8412fa91910000f
Module:Navbox
828
12
20
2025-08-20T01:22:27Z
ARTIFICER
564804
Importing default loadout
Scribunto
text/plain
-- version 1.2.5
-- config table for RANGER.
-- If you want to change the default config, DO NOT change it here,
-- please do it via the `onLoadConfig` hook in [[Module:Navbox/Hooks]].
local config = {
default_navbox_class = "navigation-not-searchable", -- Base value of the `class` parameter.
default_title_class = nil, -- Base value of the `title_class` parameter.
default_above_class = nil, -- Base value of the `above_class` parameter.
default_below_class = nil, -- Base value of the `below_class` parameter.
default_section_class =nil, -- Base value of the `section_class` parameter.
default_header_class = nil, -- Base value of the `header_class` parameter.
default_group_class = nil, -- Base value of the `group_class` parameter.
default_list_class = 'hlist', -- Base value of the `list_class` parameter.
default_header_state = nil, -- Base value of the `state` parameter.
editlink_hover_message_key = 'Navbox-edit-hover', -- The system message name for hover text of the edit icon.
auto_flatten_top_level = true, -- If true, when a section has only one list with no content and no corresponding group but has sublists, these sublists will be moved to top level.
-- This helps make the hierarchy of sections and content clearer.
-- An example:
-- {{navbox
-- ...
-- |header1 = Items
-- | group1.1 = Weapons
-- | list1.1 = Swords · Guns · Wands
-- | group1.2 = Armors
-- | list1.2 = Head pieces · Capes
-- |header2 = NPCs
-- | group2.1 = Town NPCs
-- | list2.1 = Guide · Witch
-- ...
-- }}
-- will be equal to:
-- {{navbox
-- ...
-- |header1 = Items
-- | group2 = Weapons
-- | list2 = Swords · Guns · Wands
-- | group3 = Armors
-- | list3 = Head pieces · Capes
-- |header5 = NPCs
-- | group6 = Town NPCs
-- | list6 = Guide · Witch
-- ...
-- }}
custom_render_handle = nil, -- usually for debugging purposes only. if set, it should be a function accept 2 parameters: `dataTree` and `args`, and return a string as module output.
}
---------------------------------------------------------------------
-- Argument alias.
local CANONICAL_NAMES = {
['titlestyle'] = 'title_style',
['listclass'] = 'list_class',
['groupstyle'] = 'group_style',
['collapsible'] = 'state',
['editlink'] = 'meta',
['editlinks'] = 'meta',
['editicon'] = 'meta',
['edit_link'] = 'meta',
['edit_links'] = 'meta',
['edit_icon'] = 'meta',
['navbar'] = 'meta',
['name'] = 'template',
['evenodd'] = 'striped',
['class'] = 'navbox_class',
['css'] = 'navbox_style',
['style'] = 'navbox_style',
['group'] = '1:group',
['list'] = '1:list',
}
local DEFAULT_ARGS = {
['meta'] = true,
}
local STATES = {
['no'] = '',
['off'] = '',
['plain'] = '',
['collapsed'] = 'mw-collapsible mw-collapsed',
['expanded'] = 'mw-collapsible',
}
local BOOL_FALSE = {
['no'] = true,
['off'] = true,
['false'] = true,
}
local STRIPED = {
['odd'] = 'striped-odd',
['swap'] = 'striped-odd',
['y'] = 'striped-even',
['yes'] = 'striped-even',
['on'] = 'striped-even',
['even'] = 'striped-even',
['striped'] = 'striped-even',
}
local NAVBOX_CHILD_INDICATOR = '!!C$H$I$L$D!!'
local NAVBOX_CHILD_INDICATOR_LENGTH = string.len( NAVBOX_CHILD_INDICATOR )
local CLASS_PREFIX = 'ranger-'
---------------------------------------------------------------------
local p = {}
local h = {} -- non-public
local hooks = mw.title.new('Module:Navbox/Hooks').exists and require('Module:Navbox/Hooks') or {}
---------------------------------------------------------------------
-- For templates: {{#invoke:navbox|main|...}}
function p.main(frame)
local args = p.mergeArgs(frame)
return p.build(args, true)
end
-- For modules: return require('module:navbox').build(args)
-- By default this method will skip the arguments sanitizing phase
-- (and onSanitizeArgsStart/onSanitizeArgsEnd hooks).
-- Set `doParseArgs` to true to do arguments sanitizing.
-- If `customConfig` table is provided, it will be merged into default config table (after onLoadConfig()).
-- If `customHooks` table is provided, all default hook handles will be overrided, unprovided hooks will be empty.
function p.build(args, doParseArgs, customConfig, customHooks)
if customHooks then
hooks = customHooks
end
if doParseArgs then
args = h.parseArgs(args)
end
h.runHook('onLoadConfig', config, args)
if customConfig then
for k,v in pairs(customConfig) do
config[k] = v
end
end
--merge default args
for k,v in pairs(DEFAULT_ARGS) do
if args[k] == nil then
args[k] = DEFAULT_ARGS[k]
end
end
h.runHook('onBuildTreeStart', args)
local dataTree = h.buildDataTree(args)
h.runHook('onBuildTreeEnd', dataTree, args)
if type(config.custom_render_handle) == 'function' then
return config.custom_render_handle(dataTree, args)
else
return h.render(dataTree)
end
end
-- merge args from frame and frame:getParent()
-- It may be used when creating custom wrapping navbox module.
--
-- For example, Module:PillNavbox
--
-- local RANGER = require('Module:Navbox')
-- local p = {}
-- function p.main(frame)
-- return RANGER.build(RANGER.mergeArgs(frame), true, {
-- default_navbox_class = 'pill', -- use "pill" style by default.
-- })
-- end
-- return p
--
function p.mergeArgs(frame)
local inputArgs = {}
for k, v in pairs(frame.args) do
v = mw.text.trim(tostring(v))
if v ~= '' then
inputArgs[k] = v
end
end
for k, v in pairs(frame:getParent().args) do
v = mw.text.trim(v)
if v ~= '' then
inputArgs[k] = v
end
end
return inputArgs
end
------------------------------------------------------------------------
-- equivalent to mw.text.split(str, div, true) for non-empty separator, but can be over 60x faster, since the latter is Unicode-aware.
-- Original version credit: http://richard.warburton.it.
function h.explode(div, str)
if (div=='') then return nil end
local pos,arr = 0,{}
-- for each divider found
for st,sp in function() return string.find(str,div,pos,true) end do
arr[#arr+1] = string.sub(str,pos,st-1) -- Attach chars left of current divider
pos = sp+1 -- Jump past current divider
end
arr[#arr+1] = string.sub(str,pos) -- Attach chars right of last divider
return arr
end
function h.parseArgs(inputArgs)
h.runHook('onSanitizeArgsStart', inputArgs)
local args = {}
for k, v in pairs(inputArgs) do
if type(k) == 'string' then
-- all named args have already been trimmed
local key = h.normalizeKey(k)
args[key] = h.normalizeValue(key, v)
else
args[k] = mw.text.trim(v) -- keep number-index arguments (for {{navbox|child|...}})
end
end
h.runHook('onSanitizeArgsEnd', args, inputArgs)
return args
end
-- Normalize the name string of arguments.
-- the normalized form is (index:)?name, in which:
-- index is number index such as 1, 1.3, 1.2.45,
-- name is in lowercase underscore-case, such as group, group_style
-- e.g: header_state, 1.3:list_style
-- the input argument name can be:
-- * camel-case: listStyle, ListStyle
-- * space separated: list style
-- * prefix+index+postfix?, and can be in camel-case or space/hyphen separated or mixed: list 1 style, list1, list1Style, list1_style
-- * index.name: 1.3.list
-- * index_name: 1.3_list (Space separated are treated as underscore separated, therefore 1.3 list are vaild too)
function h.normalizeKey(s)
-- camel-case to lowercase underscore-case
s = s:gsub('%l%f[%u]', '%0_') -- listStyle to list_style
s = (s:gsub(' ', '_')):lower() -- space to underscore
s = s:gsub('%l%f[%d]', '%0_') -- group1* to group_1*
s = s:gsub('%d%f[%l]', '%0_') -- *1style to *1_style
-- number format x_y_z to x.y.z
s = s:gsub('(%d)_%f[%d]', '%1%.')
-- move index to the beginning:
-- group_1.2_style to 1.2:group_style
-- group_1 to 1:group
s = s:gsub('^([%l_]+)_([%d%.]+)', '%2:%1')
-- support index.name and index_name:
-- 1.2.group / 1.2_group to 1.2:group
s = s:gsub('^([%d%.]+)[%._]%f[%l]', '%1:')
-- now the key should be in normalized form, if the origin key is vaild
-- standardize *_css to *_style
s = s:gsub('_css$', '_style')
-- standardize *collapsible to *state
s = s:gsub('collapsible$', 'state')
-- standardize all aliases to the canonical name
return CANONICAL_NAMES[s] or s
end
function h.normalizeValue(k, v)
k = tostring(k)
if k:find('_style$') then
v = (v .. ';'):gsub(';;', ';')
return v
elseif k:find('state$') then
return STATES[v]
elseif k == 'striped' then
return STRIPED[v]
elseif k == 'meta' then
return not BOOL_FALSE[v]
elseif v:sub(1, 2) == '{|' or v:match('^[*:;#]') then
-- Applying nowrap to lines in a table does not make sense.
-- Add newlines to compensate for trim of x in |parm=x in a template.
return '\n' .. v ..'\n'
end
return v
end
-- parse arguments, convert them to structured data tree
function h.buildDataTree(args)
-- parse args to a tree
local tree = h.buildTree(args)
-- build root navbox data
local data = h.buildNavboxData(tree.info)
-- Recursively build section tree
if tree.children then
data.sections = h.buildSections(tree.children, {
listClass = h.mergeAttrs(args.list_class, config.default_list_class),
listStyle = args.list_style,
groupClass = h.mergeAttrs(args.group_class, config.default_group_class),
groupStyle = args.group_style,
sectionClass = h.mergeAttrs(args.section_class, config.default_section_class),
sectionStyle = args.section_style,
headerClass = h.mergeAttrs(args.header_class, config.default_header_class),
headerStyle = args.header_style,
headerState = args.header_state or config.default_header_state,
})
end
if args[1] == 'child' then
data.CHILD_MODE = true
end
return data
end
function h.buildSections(list, defaults)
local sections = {}
local section = nil
for k, node in h.orderedPairs(list) do
local info = node.info or {}
--start a new section if needed
if info.header or not section then
section = {
class = h.mergeAttrs(info.section_class, defaults.sectionClass),
style = h.mergeAttrs(info.section_style, defaults.sectionStyle),
body = {}
}
-- Section header if needed.
-- If the value of a `|header_n=` is two or more consecutive "-" characters (e.g. --, -----),
-- it means start a new section without header, and the new section will be not collapsable.
if info.header and not string.match(info.header, '^%-%-+$') then
section.header = {
content = info.header,
class = h.mergeAttrs(info.header_class, defaults.headerClass),
style = h.mergeAttrs(info.header_style, defaults.headerStyle),
}
section.state = info.state or defaults.headerState or 'mw-collapsible'
end
sections[#sections+1] = section
end
-- above/below for this section
if info.above then
section.above = {
content = info.above,
class= h.mergeAttrs(info.above_class, config.default_above_class),
style = info.above_style,
}
end
if info.below then
section.below = {
content = info.below,
class= h.mergeAttrs(info.below_class, config.default_below_class),
style = info.below_style,
}
end
-- this group+list row
if info.group or info.list or node.children then
local row = {}
section.body[#section.body+1] = row
if info.group then
row.group = {
content = info.group,
class = h.mergeAttrs(info.group_class, defaults.groupClass),
style = h.mergeAttrs(info.group_style, defaults.groupStyle),
}
end
if info.list then
if string.sub(info.list, 1, NAVBOX_CHILD_INDICATOR_LENGTH) == NAVBOX_CHILD_INDICATOR then
-- it is from {{navbox|child| ... }}
row.sections = mw.text.jsonDecode(string.sub(info.list, NAVBOX_CHILD_INDICATOR_LENGTH+1))
else
row.list = {
content = info.list,
class = h.mergeAttrs(info.list_class, defaults.listClass),
style = h.mergeAttrs(info.list_style, defaults.listStyle),
}
end
end
-- sub-nodes, will override {{navbox|child| ... }}
if node.children then
row.sections = h.buildSections(node.children, defaults)
end
end
end
-- flatten if needed:
-- If a section has only one list with no content and no corresponding group but has sublists, these sublists will be moved to upper level.
if config.auto_flatten_top_level then
for _, sect in ipairs(sections) do
if #sect.body == 1 then
local node = sect.body[1]
if not node.group and not node.list and node.sections and #node.sections == 1 and not node.sections[1].header then
sect.body = node.sections[1].body
end
end
end
end
return sections
end
function h.buildNavboxData(info)
local data = {
state = info.state or 'mw-collapsible', -- here we need a default value for empty input
striped = info.striped,
class = h.mergeAttrs(info.navbox_class, config.default_navbox_class),
style = info.navbox_style,
}
-- data for titlebar
if info.title or info.meta or data.state ~= '' then
data.title = {
content = info.title,
class = h.mergeAttrs(info.title_class, config.default_title_class),
style = info.title_style,
}
if info.meta then
data.metaLinks = {
link = info.meta_link, -- will be used as [[$link|$text]]
url = info.meta_url, -- will be used as [$url $text], only if there is no data.metaLinks.link
text = info.meta_text, --hovertext
}
if not info.meta_link and not info.meta_url then
-- default link target
local title = mw.title.new(info.template or mw.getCurrentFrame():getParent():getTitle(), 'Template')
if not title then
error('Invalid title ' .. info.template)
end
data.metaLinks.link = title.fullText
end
if not info.meta_text then
local msg = mw.message.new(config.editlink_hover_message_key)
data.metaLinks.text = msg:exists() and msg:plain() or 'View or edit this template'
end
end
end
-- above/below
if info.above then
data.above = {
content = info.above,
class= h.mergeAttrs(info.above_class, config.default_above_class),
style = info.above_style,
}
end
if info.below then
data.below = {
content = info.below,
class= h.mergeAttrs(info.below_class, config.default_below_class),
style = info.below_style,
}
end
return data
end
-- parse arguments, convert them into a tree based on their index
-- each node on tree is { info = { #data for this node# }, children = {#children nodes#} }
function h.buildTree(args, defaults)
local tree = { info = {} }
local check = function(key, value)
local index, name = string.match(key, '^([%d%.]+):(.+)$')
-- no number index found, for root node
if not index then
tree.info[key] = value
return
end
-- filter invalid number index
if string.match(index, '^%.') or string.match(index, '%.$') or string.match(index, '%.%.') then
return
end
-- find the node that matches the index in the tree
local arr = h.explode('.', index)
local node = tree
for _, v in ipairs(arr) do
v = tonumber(v)
if not node.children then
node.children = {}
end
if not node.children[v] then
node.children[v] = { info = {} }
end
node = node.children[v]
end
node.info[name] = value
end
for k,v in pairs(args) do
check(k, v)
end
return tree
end
function h.render(data)
-- handle {{navbox|child|...}} syntax
if data.CHILD_MODE then
return NAVBOX_CHILD_INDICATOR..mw.text.jsonEncode(data.sections)
end
----- normal case -----
local out = mw.html.create()
-- build navbox container
local navbox = out:tag('div')
:attr('role', 'navigation'):attr('aria-label', 'Navbox')
:addClass(CLASS_PREFIX..'navbox')
:addClass(data.class)
:addClass(data.striped)
:addClass(data.state)
:cssText(data.style)
--title bar
if data.title then
local titlebar = navbox:tag('div'):addClass(CLASS_PREFIX..'title')
titlebar:tag('div'):addClass('mw-collapsible-toggle-placeholder')
if data.metaLinks then
titlebar:node(h.renderMetaLinks(data.metaLinks))
end
if data.title then
titlebar:addClass(data.title.class):tag('div')
:addClass(CLASS_PREFIX..'title-text')
:addClass(data.title.class)
:cssText(data.title.style)
:wikitext(data.title.content)
end
end
--above
if data.above then
navbox:tag('div')
:addClass(CLASS_PREFIX..'above mw-collapsible-content')
:addClass(data.above.class)
:cssText(data.above.style)
:wikitext(data.above.content)
:attr('id', (not data.title) and mw.uri.anchorEncode(data.above.content) or nil) -- id for aria-labelledby attribute, if no title
end
-- sections
if data.sections then
h.renderSections(data.sections, navbox, 0, true)
else
-- Insert a blank section for completely empty navbox to ensure it behaves correctly when collapsed.
if not data.above and not data.below then
navbox:tag('div'):addClass(CLASS_PREFIX..'section mw-collapsible-content')
end
end
--below
if data.below then
navbox:tag('div')
:addClass(CLASS_PREFIX..'below mw-collapsible-content')
:addClass(data.below.class)
:cssText(data.below.style)
:wikitext(data.below.content)
end
return tostring(out)..'[[Category:Pages with navboxes]]' -- suggest to use HIDDENCAT here; will be used for maintenance & gadget imports
end
function h.renderSections(data, container, level, even)
for i,sect in ipairs(data) do
--section box
local section = container:tag('div')
:addClass(CLASS_PREFIX..'section mw-collapsible-content')
:addClass(sect.class)
:addClass(sect.state)
:cssText(sect.style)
-- section header
if sect.header then
section:tag('div')
:addClass(CLASS_PREFIX..'header')
:addClass(sect.header.class)
:cssText(sect.header.style)
:tag('div'):addClass('mw-collapsible-toggle-placeholder'):done()
:tag('div'):addClass(CLASS_PREFIX..'header-text'):wikitext(sect.header.content)
end
-- above:
if sect.above then
section:tag('div')
:addClass(CLASS_PREFIX..'above mw-collapsible-content')
:addClass(sect.above.class)
:cssText(sect.above.style)
:wikitext(sect.above.content)
end
-- body: groups&lists
local box = section:tag('div'):addClass(CLASS_PREFIX..'section-body mw-collapsible-content')
even = h.renderBody(sect.body, box, level, (level==0) and true or even) -- reset even status each section
-- below:
if sect.below then
section:tag('div')
:addClass(CLASS_PREFIX..'below mw-collapsible-content')
:addClass(sect.below.class)
:cssText(sect.below.style)
:wikitext(sect.below.content)
end
end
return even
end
function h.renderMetaLinks(info)
local box = mw.html.create('span'):addClass(CLASS_PREFIX..'meta')
local meta = box:tag('span'):addClass('nv nv-view')
if info.link then
meta:wikitext('[['..info.link..'|')
:tag('span'):wikitext(info.text):attr('title', info.text):done()
:wikitext(']]')
elseif info.url then
meta:wikitext('['..info.url..' ')
:tag('span'):wikitext(info.text):attr('title', info.text):done()
:wikitext(']')
end
return box
end
function h.renderBody(info, box, level, even)
local count = 0
for _,v in h.orderedPairs(info) do
if v.group or v.list or v.sections then
count = count + 1
-- row container
local row = box:tag('div'):addClass(CLASS_PREFIX..'row')
-- group cell
if v.group or (v.sections and level > 0 and not v.list) then
local groupCell = row:tag('div')
:addClass(CLASS_PREFIX..'group level-'..level)
:addClass((level > 0) and CLASS_PREFIX..'subgroup' or nil)
local groupContentWrap = groupCell:tag('div'):addClass(CLASS_PREFIX..'wrap')
if v.group then
groupCell:addClass(v.group.class):cssText(v.group.style)
groupContentWrap:wikitext(v.group.content)
else
groupCell:addClass('empty')
row:addClass('empty-group-list')
end
else
row:addClass('empty-group')
end
-- list cell
local listCell = row:tag('div'):addClass(CLASS_PREFIX..'listbox')
if not v.list and not v.sections then
listCell:addClass('empty')
row:addClass('empty-list')
end
if v.list or (v.group and not v.sections) then
--listCell:node(h.renderList(v['list'] or '', k, level, args))
even = not even -- flip even/odd status
local cell = listCell:tag('div')
:addClass(CLASS_PREFIX..'wrap')
:addClass(even and CLASS_PREFIX..'even' or CLASS_PREFIX..'odd')
if v.list then
cell:addClass(v.list.class):cssText(v.list.style)
:tag('div'):addClass(CLASS_PREFIX..'list'):wikitext(v.list.content)
end
end
if v.sections then
local sublistBox = listCell:tag('div'):addClass(CLASS_PREFIX..'sublist level-'..level)
even = h.renderSections(v.sections, sublistBox, level+1, even)
end
end
end
if count > 0 then
box:css('--count', count) -- for flex-grow
end
return even
end
-- pairs, but sort the keys alphabetically
function h.orderedPairs(t, f)
local a = {}
for n in pairs(t) do table.insert(a, n) end
table.sort(a, f)
local i = 0 -- iterator variable
local iter = function () -- iterator function
i = i + 1
if a[i] == nil then return nil
else return a[i], t[a[i]]
end
end
return iter
end
-- For cascading parameters, such as style or class, they are merged in exact order (from general to specific).
-- Any parameter starting with multiple hyphens(minus signs) will terminate the cascade.
-- An example:
-- For group_1.1, its style is affected by parameters |group_1.1_style=... , |subgroup_level_1_style=... , and |subgroup_style=... .
-- If we have |group_1.1_style= color:red; |subgroup_level_1_style= font-weight: bold; and |subgroup_style= color: green; ,
-- the style of group_1.1 will be style="color:green; font-weight: bold; color: red;" ;
-- if we have |group_1.1_style= -- color:red; |subgroup_level_1_style= font-weight: bold; and |subgroup_style= color: green; ,
-- the style of group_1.1 will be style="color: red;" only, and the cascade is no longer performed for |subgroup_level_1_style and |subgroup_style.
function h.mergeAttrs(...)
local trim = mw.text.trim
local s = ''
for i=1, select('#', ...) do
local v = trim(select(i, ...) or '')
local str = string.match(v, '^%-%-+(.*)$')
if str then
s = trim(str..' '..s)
break
else
s = trim(v..' '..s)
end
end
if s == '' then s = nil end
return s
end
function h.runHook(key, ...)
if hooks[key] then
hooks[key](...)
end
end
-----------------------------------------------
return p
9dddb0f4a65fa1907b3503052e13630ad4bc8bb2
Module:ArgsUtil
828
13
21
2025-08-20T01:22:28Z
ARTIFICER
564804
Importing default loadout
Scribunto
text/plain
local p = {}
function p.merge()
local f = mw.getCurrentFrame()
local origArgs = f.args
local parentArgs = f:getParent().args
local args = {}
for k, v in pairs(origArgs) do
v = mw.text.trim(tostring(v))
if v ~= '' then
args[k] = v
end
end
for k, v in pairs(parentArgs) do
v = mw.text.trim(v)
if v ~= '' then
args[k] = v
end
end
return args
end
return p
1d1b2105bd857dcc5e33c8c0a8a780f67cbae72e
Module:ArgsUtil/doc
828
14
22
2025-08-20T01:22:28Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This is a basic module for processing args. Usage:
<syntaxhighlight lang="lua">
local util_args = require('Module:ArgsUtil')
local p = {}
function p.main(frame)
local args = util_args.merge() -- it is not necessary to pass a `frame` object; `merge` will generate its own
mw.logObject(args)
-- `args` now contains args passed via the template merged with defaults provided directly via the invoke.
-- anything the user sent via the template will be given priority.
end
return p
</syntaxhighlight>
== Extending this module ==
By design, {{ml|ArgsUtil}} is shipped with only a single function and no customization available; this simplifies documentation and covers nearly all use cases. An extended version of this module is available at [[support:Module:ArgsUtil|Module:ArgsUtil on the support wiki]] if you want additional functionality; and you can of course feel free to modify this module on your own wiki as needed.
6fc2a23dcff62ac5a222903e46bc56c07b0a2b1f
Module:Template link
828
15
23
2025-08-20T01:22:29Z
ARTIFICER
564804
Importing default loadout
Scribunto
text/plain
-- This code is adapted from Wikipedia
-- For the original, please see: https://en.wikipedia.org/wiki/Module:Template_link_general
-- This implements Template:Tlg
local getArgs = require('Module:ArgsUtil').merge
local p = {}
-- Is a string non-empty?
local function _ne(s)
return s ~= nil and s ~= ""
end
local nw = mw.text.nowiki
local function addTemplate(s)
local i, _ = s:find(':', 1, true)
if i == nil then
return 'Template:' .. s
end
local ns = s:sub(1, i - 1)
if ns == '' or mw.site.namespaces[ns] then
return s
else
return 'Template:' .. s
end
end
local function trimTemplate(s)
local needle = 'template:'
if s:sub(1, needle:len()):lower() == needle then
return s:sub(needle:len() + 1)
else
return s
end
end
local function linkTitle(args)
if _ne(args.nolink) then
return args[1]
end
local titleObj
local titlePart = '[['
if args[1] then
-- This handles :Page and other NS
titleObj = mw.title.new(args[1], 'Template')
else
titleObj = mw.title.getCurrentTitle()
end
titlePart = titlePart .. (titleObj ~= nil and titleObj.fullText or
addTemplate(args[1]))
local textPart = args.alttext
if not _ne(textPart) then
if titleObj ~= nil then
textPart = titleObj:inNamespace("Template") and args[1] or titleObj.fullText
else
-- redlink
textPart = args[1]
end
end
if _ne(args.subst) then
-- HACK: the ns thing above is probably broken
textPart = 'subst:' .. textPart
end
if _ne(args.brace) then
textPart = nw('{{') .. textPart .. nw('}}')
elseif _ne(args.braceinside) then
textPart = nw('{') .. textPart .. nw('}')
end
titlePart = titlePart .. '|' .. textPart .. ']]'
if _ne(args.braceinside) then
titlePart = nw('{') .. titlePart .. nw('}')
end
return titlePart
end
function p.main(frame)
local args = getArgs()
return p._main(args)
end
function p._main(args)
local bold = _ne(args.bold) or _ne(args.boldlink) or _ne(args.boldname)
local italic = _ne(args.italic) or _ne(args.italics)
local dontBrace = _ne(args.brace) or _ne(args.braceinside)
local code = _ne(args.code) or _ne(args.tt)
local show_result = _ne(args._show_result)
local expand = _ne(args._expand)
-- Build the link part
local titlePart = linkTitle(args)
if bold then titlePart = "'''" .. titlePart .. "'''" end
if _ne(args.nowrapname) then titlePart = '<span class="nowrap">' .. titlePart .. '</span>' end
-- Build the arguments
local textPart = ""
local textPartBuffer = "|"
local codeArguments = {}
local codeArgumentsString = ""
local i = 2
local j = 1
while args[i] do
local val = args[i]
if val ~= "" then
if _ne(args.nowiki) then
-- Unstrip nowiki tags first because calling nw on something that already contains nowiki tags will
-- mangle the nowiki strip marker and result in literal UNIQ...QINU showing up
val = nw(mw.text.unstripNoWiki(val))
end
local k, v = string.match(val, "(.*)=(.*)")
if not k then
codeArguments[j] = val
j = j + 1
else
codeArguments[k] = v
end
codeArgumentsString = codeArgumentsString .. textPartBuffer .. val
if italic then
val = '<span style="font-style:italic;">' .. val .. '</span>'
end
textPart = textPart .. textPartBuffer .. val
end
i = i + 1
end
-- final wrap
local ret = titlePart .. textPart
if not dontBrace then ret = nw('{{') .. ret .. nw('}}') end
if _ne(args.a) then ret = nw('*') .. ' ' .. ret end
if _ne(args.kbd) then ret = '<kbd>' .. ret .. '</kbd>' end
if code then
ret = '<code>' .. ret .. '</code>'
elseif _ne(args.plaincode) then
ret = '<code style="border:none;background:transparent;">' .. ret .. '</code>'
end
if _ne(args.nowrap) then ret = '<span class="nowrap">' .. ret .. '</span>' end
--[[ Wrap as html??
local span = mw.html.create('span')
span:wikitext(ret)
--]]
if _ne(args.debug) then ret = ret .. '\n<pre>' .. mw.text.encode(mw.dumpObject(args)) .. '</pre>' end
if show_result then
local result = mw.getCurrentFrame():expandTemplate{title = addTemplate(args[1]), args = codeArguments}
ret = ret .. " → " .. result
end
if expand then
local query = mw.text.encode('{{' .. addTemplate(args[1]) .. string.gsub(codeArgumentsString, textPartBuffer, "|") .. '}}')
local url = mw.uri.fullUrl('special:ExpandTemplates', 'wpInput=' .. query)
mw.log()
ret = ret .. " [" .. tostring(url) .. "]"
end
return ret
end
return p
45d40a4bff9a1d0eb4274f56fb2f17849aa68728
Module:Template link/doc
828
16
24
2025-08-20T01:22:30Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{From Wikipedia|Module:Template link general}}
1a395265ccbd055518c1d14b52362cc148b89c81
Module:Main page
828
17
25
2025-08-20T01:22:31Z
ARTIFICER
564804
Importing default loadout
Scribunto
text/plain
local p = {}
local h = {}
-- merge args from frame and frame:getParent()
function h.mergeArgs(frame)
local inputArgs = {}
for k, v in pairs(frame.args) do
v = mw.text.trim(tostring(v))
if v ~= '' then
inputArgs[k] = v
end
end
for k, v in pairs(frame:getParent().args) do
v = mw.text.trim(v)
if v ~= '' then
inputArgs[k] = v
end
end
return inputArgs
end
--------------------------------------------------------------------
function p.main(frame)
local args = h.mergeArgs(frame)
-- use the rootpage parameter if given, otherwise use the current page name
local rootpage = args['rootpage'] or mw.title.getCurrentTitle().fullText
local layouts = {'desktop', 'tablet', 'mobile'}
for _,layout in pairs(layouts) do
-- collapse consecutive line breaks and spaces, then trim
-- we need to check for permutations of " \n" because trim can't clean that up if it's in the middle of the string
args[layout] = mw.text.trim(args[layout]):gsub("\n\n+", "\n"):gsub(" +", " "):gsub(" \n", "\n"):gsub("\n ", "\n")
end
-- parse the arguments into CSS variables that contain legal syntax for grid-template-areas
local desktop = "--main-page-layout--desktop: '" .. string.gsub(args['desktop'], '\n', "' '") .. "';"
local tablet = "--main-page-layout--tablet: '" .. string.gsub(args['tablet' ], '\n', "' '") .. "';"
local mobile = "--main-page-layout--mobile: '" .. string.gsub(args['mobile' ], '\n', "' '") .. "';"
-- grid-template-columns overrides
local desktop_cols = mw.text.trim(string.gsub(args['desktop-columns'] or '', ';', ''))
local tablet_cols = mw.text.trim(string.gsub(args[ 'tablet-columns'] or '', ';', ''))
local mobile_cols = mw.text.trim(string.gsub(args[ 'mobile-columns'] or '', ';', ''))
-- set the variables used by grid-template-columns
if desktop_cols ~= '' then
desktop = desktop .. '--main-page-layout-columns--desktop: '.. desktop_cols ..';'
end
if tablet_cols ~= '' then
tablet = tablet .. '--main-page-layout-columns--tablet: '.. tablet_cols ..';'
end
if mobile_cols ~= '' then
mobile = mobile .. '--main-page-layout-columns--mobile: '.. mobile_cols ..';'
end
local boxes = {} -- list of all boxes as a simple list, used to set the order of appearance
local seen_boxes = {} -- list of all boxes as a k:v pair, used to filter out duplicates
local boxes_in_layout = {} -- list of layouts, then list of all boxes in that layout
local missing_boxes = {} -- list of layouts, then list of boxes that are *not* included in that layout
-- add every box referenced in the layout rules once
function parse_layout(layout)
for _,name in pairs(mw.text.split(mw.text.trim(args[layout]), '%s')) do
if not seen_boxes[name] then
boxes[#boxes+1] = name -- table with numerical keys for set html order
seen_boxes[name] = true
end
boxes_in_layout[layout][name] = true
end
end
-- loop through the layouts the first time to set up the box lists
for _,layout in pairs(layouts) do
boxes_in_layout[layout] = {}
missing_boxes[layout] = {}
parse_layout(layout)
end
-- then loop through the layouts a second time because we need to compare those completed lists to check for missing boxes
for _,layout in pairs(layouts) do
for _,name in pairs(boxes) do
if boxes_in_layout[layout][name] ~= true then
mw.addWarning( 'WARNING: the \"' .. name .. '\" box is missing in the ' .. layout .. ' layout. If this is intentional, you can ignore this warning.')
missing_boxes[layout][name] = true
end
end
end
-- start our mp-container wrapper, and add our variables from earlier as inline styles to declare them
-- the rootpage is added to the dataset so it's easily accessible by mp-edit-links.js and it doesn't need to make its own API call
local output = mw.html.create()
local container = output:tag('div'):attr('id', 'mp-container'):cssText(desktop .. tablet .. mobile):attr('data-rootpage', rootpage)
-- loop through boxes and add the relevant main page subpages into the output
for _,box in pairs(boxes) do
mw.ext.VariablesLua.vardefine('imp-variable-id', box) -- using a vardefine lets us pass this directly to the template without going through the user-facing box
local pre_vardefine = ''
for _,layout in pairs(layouts) do
pre_vardefine = pre_vardefine .. (missing_boxes[layout][box] and '0' or '1') .. ','
end
-- formatted as a psuedo-bitmask to reduce variable usage, "<display-on-destop>, <display-on-tablet>, <display-on-mobile>," each value is 0 or 1 (trailing comma is insignificant)
-- expected to be used with #explode in the template receiving the variable
mw.ext.VariablesLua.vardefine('imp-variable-display-box', pre_vardefine)
if mw.title.new(rootpage .. '/' .. box).exists then
container:wikitext(frame:expandTemplate{ title = ':' .. rootpage .. '/' .. box})
else
container:wikitext(frame:expandTemplate{ title = 'Main page box/missing', args = { box, rootpage = rootpage}}) -- See [[Template:Main page box/missing]]
end
end
return output
end
return p
c6237f93b472a243ae7393913c285b3ae62c08f5
Module:Navbox/Hooks
828
18
26
2025-08-20T01:22:32Z
ARTIFICER
564804
Importing default loadout
Scribunto
text/plain
-- as of Module:Navbox version 1.2.5
local p = {}
---------------------------------------------------
-- Runs before RANGER does args sanitizing
-- `inputArgs` is the merged input arguments from the template (frame.args + frame:getParent().args)
function p.onSanitizeArgsStart(inputArgs)
end
-- Runs after RANGER does args sanitizing
-- `args` parameter is the sanitized arguments table with normalized keys (in lowercase underscore-case with canonical names) and normalized values.
function p.onSanitizeArgsEnd(args, inputArgs)
end
-- Runs when RANGER loads config table (after onSanitizeArgsEnd and before onBuildTreeStart)
-- `config` parameter is the default config table.
-- `args` parameter is the sanitized arguments table (has not yet merged the DEFAUT_ARGS table).
function p.onLoadConfig(config, args)
end
-- Runs before RANGER converts sanitized arguments table to structured data tree
-- `args` parameter is the sanitized arguments table that has the DEFAUT_ARGS merged.
function p.onBuildTreeStart(args)
end
-- Runs after RANGER converts sanitized arguments table to structured data tree
-- `tree` parameter is the structured data.
-- `args` parameter is the sanitized arguments table.
function p.onBuildTreeEnd(tree, args)
end
---------------------------------------------------
return p
a124a9f396b4a5a6c91de416c6cb8af5342f41fb
Module:Navbox/doc
828
19
27
2025-08-20T01:22:32Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This module is used by [[Template:Navbox]].
87d5c562165cd75b963e03aa428c80413bacff30
Template:Documentation
10
20
28
2025-08-20T01:22:33Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
--><div class="documentation"><!--
--><div class="documentation-header"><!--
-->[[File:Template-{{#ifexist:{{#vardefineecho:docpage|{{{1|Template:{{#replace:{{{1|{{PAGENAME}}/doc}}}|Template:|}}}}}<!-- end vde -->}}|{{#if:{{{baddoc|}}}|bad}}|no}}info.svg|50px|link=]] <!--
--><span style="font-weight: bold; font-size: 125%; margin-right: 10px;">Documentation</span> <!--
-->{{#ifeq:{{SUBPAGENAME}}|doc|<!--nothing-->|<!--
-->{{#ifexist:{{#var:docpage}}|<!--
--><span style="font-size: 90%; font-style: italic;"><!--
-->[{{fullurl:{{#var:docpage}}|action=edit}} Edit] this documentation at [{{fullurl:{{#var:docpage}}|redirect=no}} {{FULLPAGENAMEE:{{#var:docpage}}}}].<!--
--></span><!--
-->}}<!--
-->}}<!--
--><div style="text-align: right; margin-left: 5px;"><!--
-->([{{fullurl:{{FULLPAGENAMEE}}/doc|action=edit}} edit] • [{{fullurl:{{FULLPAGENAMEE}}/doc|action=history}} history] • [{{fullurl:{{FULLPAGENAMEE}}|action=purge}} purge])<!--
--></div><!--
--></div><!--
<!-- leave line break here -->
{{#if:{{{lua|}}}|{{UsesLua|{{{lua}}} }} }}
<!-- documentation text/error box begins here -->
<div style="border-radius: 5px; border: 2px solid var(--wiki-content-border-color); margin: 0.5em auto 1em; padding: 0.8em 1.2em; background: var(--wiki-content-background-color--secondary);">
<!--
-->{{#ifexist:{{#var:docpage}}|<!--
If there is documentation
-->
{{ {{#var:docpage}} }}
<!--
Else
-->|<!--
-->No documentation subpage exists yet for this template. [{{fullurl:{{FULLPAGENAMEE:Template:{{{1|{{PAGENAME}}}}}}}/doc|action=edit&preload=Template:Documentation/preload}} Create one now].<!--
-->[[Category:Templates with no documentation]]<!--
-->}}<!-- leave line break here -->
<!-- documentation text/error box ends here -->
</div>
<!-- -->{{#ifeq:{{SUBPAGENAME}}|doc|<!--
-->{{#ifeq:{{BASEPAGENAME}}|Doc|<!--nothing-->|<!-- only if page is not Template:Documentation
-->This is the documentation page, it should be transcluded into the main template page. See {{tlx|doc}} for more information. <!--
-->[[Category:Template documentation]]<!--
-->}}<!--
-->}}<!--
--></div><!--
--></includeonly><!--
--><noinclude>{{Documentation}}
[[Category:Documentation templates| ]]
</noinclude>
c4c3117e700d89854599fb352f60792ed2165be0
Template:Luadoc
10
21
29
2025-08-20T01:22:33Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<noinclude>[[Category:Documentation templates]]</noinclude>{{#ifeq:{{int:scribunto-doc-page-name|{{ROOTPAGENAME}}}}|{{FULLPAGENAME}}||<div class="luadoc">Edit the [[{{int:scribunto-doc-page-name|{{ROOTPAGENAME}}}}|documentation or categories]] for this module. {{#ifexist:{{FULLPAGENAME}}/i18n|This module has an [[/i18n|i18n file]].}}</div>}}
37de49949dfa0f16975ff4e9850b4573ec388cb6
Template:MP link
10
22
30
2025-08-20T01:22:34Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
Variables
-->{{#vardefine:link|{{{link|{{{1|}}}}}}}}<!--
Image-->{{#if:{{{image|}}}|[[File:{{#replace:{{{image|}}}|File:}}|{{{size|42px}}}|link={{#var:link}}{{#if:{{{altText|}}}|{{!}}alt={{{altText|}}}}}|class={{{imageClass|}}}]]}}<!--
Link below the image
-->{{#if:{{{1|}}}|<!--
If it's an external link, use external link syntax -->{{#if:{{#pos:{{{link|}}}|http}}|[{{{link|}}} {{{1|}}}]|<!--
Otherwise use normal syntax
the ifeq, pos, sub combo is filtering out a leading :, so that we can add our own without doubling up, allowing easy category linking
-->[[:{{#ifeq:{{#pos:{{#var:link}}|:}}|0|{{#sub:{{#var:link}}|1}}|{{#var:link}}}}|{{{1|}}}]]}}
}}</includeonly><noinclude>
{{doc}}
[[Category:Main page templates]]
</noinclude>
be5325327a3e6c626069e9f98a5dd2b9f283042c
Template:MP link/doc
10
23
31
2025-08-20T01:22:35Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This creates one of the stylized and formatted links on the [[{{MediaWiki:Mainpage}}|main page]].
== Usage ==
Groups of this template should be wrapped inside of <code><nowiki><div class="mp-links"></div></nowiki></code> and each entry should be a separate line in an [[wikipedia:Help:Lists#Basically|unordered list]]. This div can be given one of the classes <code>columns-x</code> where x is a number from 1 to 8, and the links will line up in that many columns if space permits (default is 3). The div can also optionally be given the class <code>stretch</code> and it will stretch the list vertically to fill empty space. See [[Mediawiki:Common.css]] for the full definitions of these classes and styling for this template.
===Parameters===
<templatedata>
{
"description": {
"en": "Creates stylized and formatted links on the main page."
},
"format": "inline",
"params": {
"1": {
"label": {
"en": "Text"
},
"description": {
"en": "The text to display. If the link parameter is not given, this will also be the link target."
},
"example": "Stuff",
"type": "string",
"suggested": true
},
"link": {
"label": {
"en": "Link"
},
"description": {
"en": "The target page for the link, if different than the display text."
},
"required": false,
"example": "Main Page",
"type": "wiki-page-name"
},
"image": {
"label": {
"en": "Image"
},
"description": {
"en": "An image to display with the link."
},
"required": false,
"suggested": true,
"type": "wiki-file-name"
},
"size": {
"label": {
"en": "Image size"
},
"description": {
"en": "The size of the image, in px."
},
"required": false,
"default": "42px",
"type": "string"
},
"imageClass": {
"label": "Image class",
"description": "A class to give directly to the image",
"example": "invert-on-dark",
"type": "string",
"suggestedvalues": [
"invert-on-dark",
"invert-on-light"
]
},
"altText": {
"label": "Alt text",
"description": "Alt text to describe the image",
"example": "Wiki logo",
"type": "string",
"suggested": true
}
},
"paramOrder": [
"1",
"link",
"image",
"size",
"imageClass",
"altText"
]
}
</templatedata>
==Examples==
<pre>
<div class="mp-links columns-3">
* {{MP link|Stuff|link=Special:Random|image=Site-logo.png|size=42px}}
* {{MP link|Things|link=Special:Random}}
* {{MP link|Other stuff|link=Special:Random|image=Site-logo.png|size=42px}}
</div>
</pre>
Produces:
<div class="mp-links columns-3">
* {{MP link|Stuff|link=Special:Random|image=Site-logo.png|size=42px}}
* {{MP link|Things|link=Special:Random}}
* {{MP link|Other stuff|link=Special:Random|image=Site-logo.png|size=42px}}
</div>
<noinclude>
[[Category:Template documentation]]
</noinclude>
0df5d36904353428acb21882bd8923560f77a142
Template:Doc
10
24
32
2025-08-20T01:22:36Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:Documentation]]
041222999c2c4765a4663432058f50686fb65f40
Template:Uses Lua
10
25
33
2025-08-20T01:22:36Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = darkblue
| icon = Lua logo.svg
| title= This template uses one or more modules written in the Lua programming language.
| message = For more information, see [[wikipedia:Wikipedia:Lua|Wikipedia:Lua]] or the [[mw:Extension:Scribunto/Lua reference manual|Lua reference manual on mediawiki.org]]. Modules used include: {{#if:{{{1|}}}|{{#arraymap:{{{1|}}}|,|%s|'''[[Module:%s|%s]]'''}}|''None provided''}}.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
}}</includeonly><noinclude>{{doc|Template:Ambox/doc}}</noinclude>
1930c9b36136a5562cfaf7584f811d62b114a58a
Template:Ambox
10
26
34
2025-08-20T01:22:37Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
--><div class="ambox {{{class|}}} {{#ifeq:{{lc:{{{tiny|}}}}}|yes|tiny}} noexcerpt"<!--
--> style="{{#if:{{{color|}}}|--ambox-color: {{{color|}}};<!-- /if -->}}"><!--
--><div class="ambox-icon metadata <!-- the metadata class stops it from showing in MediaViewer -->">[[File:{{{icon|Ambox banner content.svg}}}{{!}}{{#ifeq:{{lc:{{{tiny|}}}}}|yes|48x20px|48x48px}}|alt=|link=]]</div><!--
--><div class="ambox-content"><!-- start ambox content
-->{{#if: {{{title|}}} | <p class="ambox-title">{{{title}}}</p> }}<!--
--><p class="ambox-text">{{{message|No text provided.}}}{{#if: {{{date|}}} |<nowiki> </nowiki>(Message added: {{{date}}}) }}</p><!--
--></div><!-- end ambox content
--></div><!-- end ambox
--></includeonly><noinclude>
{{doc}}
[[Category:Notice templates]]</noinclude>
11c1d0a1c9c2fcd4b89b27313303decfae03dea7
Template:((
10
27
35
2025-08-20T01:22:37Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{<noinclude>{{documentation}}</noinclude>
a506ba66cf7c806baae7faecb221b3a946721f6a
Template:Tlx
10
28
36
2025-08-20T01:22:38Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:Tl]]
af3906f239c45d791753d3170c656eddd6d1af5f
Template:Tl
10
29
37
2025-08-20T01:22:38Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#invoke:Template link|main|code=on}}</includeonly><noinclude>
{{Documentation}}
</noinclude>
1c13b1daaf7b7e8ce1e45cc03b4baf31c09bc6cd
Template:Tl/doc
10
30
38
2025-08-20T01:22:39Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{From Wikipedia|Module:Template link general,Template:Tlx}}
{{Uses Lua|Template link}}
This template returns an exemplaric use of a template while linking to the template description page, if the template exists.
== Usage ==
<pre>
{{tl|<Template name>}}
{{tl|<Template name>|<Template parameters>}}
</pre>
; ''unnamed parameter'' 1
: Template name (without <code>Template:</code> prefix)
; ''unnamed parameter'' 2 - 9
: Optional. Template parameters
; nl
: Optional flag to display an un-linked template usage.
== Examples ==
: <code><nowiki>{{tl|stub}}</nowiki></code> returns {{tl|stub}}
: <code><nowiki>{{tl|stub|1}}</nowiki></code> returns {{tl|stub|1}}
: <code><nowiki>{{tl|stub|1|2|nl{{=}}y}}</nowiki></code> returns {{tl|stub|1|2|nl{{=}}y}}
: <code><nowiki>{{tl|for|page|t1{{=}}alt text}}</nowiki></code> returns {{tl|for|page|t1{{=}}alt text}}
== See also ==
<includeonly>
[[Category:Formatting templates]]
</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
7cb4f0fa749ef8a18a48c4b5816357a225f4acee
Template:Nowrap
10
31
39
2025-08-20T01:22:39Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<span class="nowrap">{{{1}}}</span><noinclude>
{{documentation}}
</noinclude>
8817bafce418a08a72f3425283fc03d04a2d8d44
Template:))
10
32
40
2025-08-20T01:22:40Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
}}<noinclude>
{{documentation}}
</noinclude>
85ca77d4d6ff71d8e6396ebd798f87fa7f45dc02
Template:))/doc
10
33
41
2025-08-20T01:22:41Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:No wrap
10
34
42
2025-08-20T01:22:41Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:Nowrap]]
269180d5083536bbbf72d889477805cfde7aac9e
Template:Normal
10
35
43
2025-08-20T01:22:42Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<span style{{=}}"font-weight:normal; font-style:normal">{{{1}}}</span><noinclude>
{{documentation}}
</noinclude>
f1d74e033cde1ce3b2efdc98b78fb863b8524fcf
Template:((/doc
10
36
44
2025-08-20T01:22:42Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{| class="wikitable" style="text-align:center"
|-
! scope="col" style="width:7.0em;" | {{no wrap|Template call}}<br>{{normal|('''m''' for magic word)}}
! scope="col" style="width:5.75em;" | {{no wrap|Output}} {{normal|(delayed interpretation as wikimarkup)}}
! scope="col" style="width:9.0em;" | {{no wrap|HTML alternative}} {{normal|(never interpreted as wikimarkup)}}
! Why you might want to use this
|- style="vertical-align:top"
| <code><nowiki>{{!}}</nowiki></code> '''(m)'''
| <nowiki>|</nowiki>
| &#124; or {{tl|pipe}}
| Displaying pipe characters inside of a parser function
|- style="vertical-align:top"
| <code><nowiki>{{=}}</nowiki></code> '''(m)'''
| <nowiki>=</nowiki>
| &#61;
| Displaying equal signs inside of unnamed parameters (e.g. <code><nowiki>{{MyTemplate|1+1=2}}</nowiki></code> will assign <code>2</code> to <code><nowiki>{{{1+1|}}}</nowiki></code>; <code><nowiki>{{MyTemplate|1+1{{=}}2}}</nowiki></code> will do what you want)
|- style="vertical-align:top"
| {{tlx|!!}}
| <nowiki>||</nowiki>
| &#124;&#124;
| Displaying a break between two table cells inside of a parser function
|- style="vertical-align:top"
| {{tlx|!(}}
| {{!(}}
| &#91;
| Displaying a bracket inside of an external link
|- style="vertical-align:top"
| {{tlx|)!}}
| {{)!}}
| &#93;
| Displaying a bracket inside of an external link
|- style="vertical-align:top"
| {{tlx|!((}}
| {{!((}}
| &#91;&#91;
| Displaying a bracket inside of a link
|- style="vertical-align:top"
| {{tlx|))!}}
| {{))!}}
| &#93;&#93;
| Displaying a bracket inside of a link
|- style="vertical-align:top"
| {{tlx|(}}
| {{(}}
| &#123;
| Escaping a single brace immediately next to a template or parser function to avoid turning it into a parameter
|- style="vertical-align:top"
| {{tlx|)}}
| {{)}}
| &#125;
| Escaping a single brace immediately next to a template or parser function to avoid turning it into a parameter
|- style="vertical-align:top"
| {{tlx|((}}
| {{((}}
| &#123;&#123;
| Displaying open braces for a template without actually transcluding that template
|- style="vertical-align:top"
| {{tlx|))}}
| {{))}}
| &#125;&#125;
| Displaying closed braces for a template without actually transcluding that template
|- style="vertical-align:top"
| {{tlx|(((}}
| {{(((}}
| &#123;&#123;&#123;
| Displaying a template parameter's open curly braces without actually using that variable
|- style="vertical-align:top"
| {{tlx|)))}}
| {{)))}}
| &#125;&#125;&#125;
| Displaying a template parameter's closed curly braces without actually using that variable
|- style="vertical-align:top"
| {{tlx|(!}}
| <nowiki>{|</nowiki>
| &#123;&#124;
| Starting a table inside of a parser function
|- style="vertical-align:top"
| {{tlx|!-}}
| <nowiki>|-</nowiki>
| &#124;&#45;
| Starting a new table row inside of a parser function
|- style="vertical-align:top"
| {{tlx|!)}}
| <nowiki>|}</nowiki>
| &#124;&#125;
| Closing a table inside of a parser function
|}<includeonly>
[[Category:Formatting templates]]
</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
9e1eb11bc0644d97b4cc9bc4445c3f0bacdd339d
Template:!(
10
37
45
2025-08-20T01:22:43Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[<noinclude>
{{documentation}}</noinclude>
1b058774deae9a7e511a0486a04647d6a3b9af62
Template:!(/doc
10
38
46
2025-08-20T01:22:44Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:)!
10
39
47
2025-08-20T01:22:44Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
]<noinclude>
{{documentation}}</noinclude>
016897dfd1af3b146bed2b47e7aa58c0bbf6f23d
Template:)!/doc
10
40
48
2025-08-20T01:22:45Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:!((
10
41
49
2025-08-20T01:22:46Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[<noinclude>
{{documentation}}</noinclude>
a331374acf15177afbb3ffc0ec7bd5ada14c582e
Template:!((/doc
10
42
50
2025-08-20T01:22:46Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:))!
10
43
51
2025-08-20T01:22:47Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
]]<noinclude>
{{documentation}}</noinclude>
3d84066ce45d0c1fca0bb04608a4e73c6ea54324
Template:))!/doc
10
44
52
2025-08-20T01:22:47Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:Navbox
10
45
53
2025-08-20T01:22:48Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#invoke:Navbox|main}}</includeonly><noinclude>[[Category:Navigation templates]] {{documentation}}</noinclude>
11355a4514de8aa6c0ae686240591d267101c58c
Template:Navbox/doc
10
46
54
2025-08-20T01:22:48Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{no direct use}}
{{UsesLua|Navbox}}
This template is designed to set up navigational templates relatively quickly with one or more lists of links. We highly recommend using this template for standardizing navigational templates and ease of use, especially for mobile devices.
See [[support:RANGER navboxes|the support wiki]] for more information, including installation steps and further examples.
== Basic example ==
The following example demonstrates the core functionality of this template: the title text, one standard link group, and one link group that contains two sub-groups. The rows are striped for easier readability.
{{Navbox
| title = Items
| striped = even
| group1 = Consumables
| list1 =
* Health Potion
* Mana Potion
| group2 = Weapons
| group2.1 = Swords
| list2.1 =
* Wooden Sword
* Rusted Sword
* Steel Sword
| group2.2 = Bows
| list2.2 =
* Shortbow
* Crossbow
* Longbow
}}
<syntaxhighlight lang="wikitext" style="overflow: auto;">
{{Navbox
| template = <template_title> <!-- Required. e.g. `|template=Items` for template:Items -->
| title = Items
| striped = even
| group1 = Consumables
| list1 =
* Health Potion
* Mana Potion
| group2 = Weapons
| group2.1 = Swords
| list2.1 =
* Wooden Sword
* Rusted Sword
* Steel Sword
| group2.2 = Bows
| list2.2 =
* Shortbow
* Crossbow
* Longbow
}}
</syntaxhighlight>
== Parameters ==
=== Main ===
The following parameters modify the navbox as a whole.
{| class="wikitable"
! Parameter
! Description
|-
! <code>template</code><br><code>name</code>
| ('''Required''') Title of the template that the edit icon links to. e.g. <code>Items</code> for template:Items.
|-
! <code>title</code>
| Text that appears at the top of the navbox.
|-
! <code>state</code><br><code>collapsible</code>
| Controls if a navbox should be expanded or collapsed when the page loads. This only affects the whole navbox; if [[#Sections|sections]] are used, they are treated differently.
* <code>expanded</code> ('''default''') - the navbox will start open and readers can collapse it.
* <code>collapsed</code> - the navbox will start closed and readers can expand it.
* <code>off</code>, <code>no</code>, or <code>plain</code> - the navbox will start open and cannot be collapsed.
Advanced users can modify this on a page-by-page basis; see [[support:RANGER navboxes#Controlling the collapsible|the support wiki]] for more information.
|-
! <code>editlinks</code>
| Controls if an edit icon should be displayed at the top-left of the navbox, making it easier for users to interact with the template itself.
* unset ('''default''') - displays the edit icon
* <code>off</code> or <code>no</code> - hides the edit icon
|-
! <code>above</code>
| Text that appears above all list groups, directly below the title.
|-
! <code>below</code>
| Text that appears below all list groups, at the bottom of the navbox.
|-
! <code>striped</code><br><code>evenodd</code>
| Controls if the navbox rows should have zebra striping on even or odd rows, making it easier for users to distinguish two rows apart from each other. If [[#Sections|sections]] are used, each section resets the even/odd counter.
*unset ('''default''') - all rows have the same background
*<code>y</code>, <code>yes</code>, <code>on</code>, <code>striped</code>, or <code>even</code> - even-numbered rows are highlighted
*<code>swap</code> or <code>odd</code> - odd-numbered rows are highlighted
|}
=== Sections ===
The following parameters define sections within the navbox with their own titles.
{| class="wikitable"
! Parameter
! Description
|-
! <code>header''n''</code>
| Text that appears at the top of the section, where ''n'' is any positive integer. If the value is set to two or more <code>-</code> (e.g. <code>--</code>, <code>-----</code>, etc.) the new section will have no header bar and cannot be collapsed.
All groups and lists that are ''n'' or higher will appear in this section unless there is a higher <code>header''n''</code> later in the template. For example, if a navbox defines <code>header1</code> and <code>header4</code>, the first section will include <code>list1</code>, <code>list2</code>, and <code>list3</code> (and any of their sub-lists), while the second section will include all remaining lists starting at <code>list4</code> and their sub-lists.
|-
! <code>header_state</code><br><code>state''n''</code>
| <code>header_state</code> controls if all sections, by default, should be expanded or collapsed when the page loads.
<code>state''n''</code> overrides <code>header_state</code> for the specific section defined by <code>header''n''</code> (where ''n'' is a matching integer).
* <code>expanded</code> ('''default''') - the section will start open and readers can collapse it.
* <code>collapsed</code> - the section will start closed and readers can expand it.
* <code>off</code> or <code>plain</code> - the section will start open and cannot be collapsed.
Advanced users can modify these on a page-by-page basis; see [[support:RANGER navboxes#Controlling the collapsible|the support wiki]] for more information.
Both parameters have no effect on sections with headers set to two or more <code>-</code>, which are always expanded and cannot be collapsed.
|}
=== List groups ===
The following parameters define the list groups.
{| class="wikitable"
! Parameter
! Description
|-
! <code>group''n''</code>
| Text label for a list, which appears on the left on desktop or at the top on mobile, where ''n'' is any positive integer.
This parameter is optional; if a <code>list''n''</code> does not have a matching <code>group''n''</code>, the list will take the full width on desktop.
|-
! <code>list''n''</code>
| A wikitext list, where ''n'' is any positive integer.
|-
! <code>group''n''.''x''</code><br><code>group''n''.''x''.''y''</code><br>etc.
| Text label for sub-lists that appear under <code>group''n''</code>, <code>group''n''.''x''</code>, etc.
|-
! <code>list''n''.''x''</code><br><code>list''n''.''x''.''y''</code><br>etc.
| Wikitext sub-lists.
|}
=== Styling ===
The following parameters add inline styling or your custom CSS classes to specific elements of the navbox.
To assist with text alignment, three default classes are available: <code>align-left</code>, <code>align-center</code>, and <code>align-right</code>.
{| class="wikitable"
! Parameter
! Description
|-
! <code>navbox_style</code><br><code>navbox_class</code>
| Modifies the parent navbox element; <code>class</code> can be used as a shorthand for <code>navbox_class</code>
Two default classes are available:
*<code>pill</code> changes the links to pill-styled rather than dot-separated
*<code>pill-mobile</code> only changes the links to pill-styled on mobile devices
|-
! <code>title_style</code><br><code>title_class</code>
| Modifies the title bar
|-
! <code>above_style</code><br><code>above_class</code>
| Modifies the <code>above</code> text row
|-
! <code>below_style</code><br><code>below_class</code>
| Modifies the <code>below</code> text row
|-
! <code>header_style</code><br><code>header_class</code>
| Modifies all section headers (''not'' the title bar)
|-
! <code>header''n''_style</code><br><code>header''n''_class</code>
| Modifies the specific section header ''n''
|-
! <code>section''n''_style</code><br><code>section''n''_class</code>
| Modifies the container holding the section defined by a matching <code>header''n''</code>
|-
! <code>group_style</code><br><code>group_class</code>
| Modifies all base groups (<code>group''n''</code>), but ''not'' any subgroups (<code>group''n''.''x''</code>, etc.)
|-
! <code>subgroup_style</code><br><code>subgroup_class</code>
| Modifies all subgroups at all levels (<code>group''n''.''x''</code>, <code>group''n''.''x''.''y''</code>, etc.)
|-
! <code>group''A''_style</code><br><code>group''A''_class</code>
| Modifies the specific group ''A'', where ''A'' is any ''n'', ''n''.''x'', ''n''.''x''.''y'', etc.
|-
! <code>list_style</code><br><code>list_class</code>
| Modifies all lists. Note, in this context, "list" refers to the container of a <code>list''n''</code> parameter, not a <code>ul</code> or <code>ol</code> element inside the parameter
|-
! <code>list''A''_style</code><br><code>list''A''_class</code>
| Modifies the specific list ''A'', where ''A'' is any ''n'', ''n''.''x'', ''n''.''x''.''y'', etc.
|}
<noinclude>[[Category:Template documentation]]</noinclude>
e35c990efd00644e63b9735d72ff65818357a1fb
Template:(
10
47
55
2025-08-20T01:22:49Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{<noinclude>
{{documentation}}</noinclude>
490a0c9c85eff213addd7272fe40f8627a637c75
Template:(/doc
10
48
56
2025-08-20T01:22:49Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:)
10
49
57
2025-08-20T01:22:50Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
}<noinclude>
{{documentation}}</noinclude>
3bf19eb36f7371f1b4b61b8efbba67dfb0e8cfd4
Template:)/doc
10
50
58
2025-08-20T01:22:51Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:(((
10
51
59
2025-08-20T01:22:51Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{{<noinclude>
{{documentation}}</noinclude>
fa33084b57c1f33c82290de279827b973ab2fba8
Template:(((/doc
10
52
60
2025-08-20T01:22:52Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:)))
10
53
61
2025-08-20T01:22:52Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
}}}<noinclude>
{{documentation}}</noinclude>
585d94f6fe636b77087dc0d06bfbe6cb69b29987
Template:)))/doc
10
54
62
2025-08-20T01:22:53Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:Documentation/doc
10
55
63
2025-08-20T01:22:53Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Use {{tl|documentation}} inside of the <code><nowiki><noinclude></noinclude></nowiki></code> section on your template. Then create your template at the <code>/doc</code> subpage of your template.
<noinclude>[[Category:Template documentation]]</noinclude>
055b0481a1967951c59f15a09b92767c90baa8dd
Template:License/CC-BY-NC-ND
10
56
64
2025-08-20T01:22:54Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-NC-ND
| icon = [[File:CC-BY-NC-ND.svg|x50px|link=https://creativecommons.org/licenses/by-nc-nd/3.0/|CC-BY-NC-ND]]
| text = This file is under the [https://creativecommons.org/licenses/by-nc-nd/3.0/ Creative Commons Attribution-NonCommercial-NoDerivs 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-NC-ND}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
4ed8a6372d14a167dd9d26f1ae865b1593b76604
65
64
2025-08-20T01:22:55Z
ARTIFICER
564804
Protected "[[Template:License/CC-BY-NC-ND]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-NC-ND
| icon = [[File:CC-BY-NC-ND.svg|x50px|link=https://creativecommons.org/licenses/by-nc-nd/3.0/|CC-BY-NC-ND]]
| text = This file is under the [https://creativecommons.org/licenses/by-nc-nd/3.0/ Creative Commons Attribution-NonCommercial-NoDerivs 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-NC-ND}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
4ed8a6372d14a167dd9d26f1ae865b1593b76604
Template:License/CC-BY-SA
10
57
66
2025-08-20T01:22:55Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-SA
| icon = [[File:CC-BY-SA.svg|x50px|link=https://creativecommons.org/licenses/by-sa/3.0/|CC-BY-SA]]
| text = This file is under the [https://creativecommons.org/licenses/by-sa/3.0/ Creative Commons Attribution-ShareAlike 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-SA}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
1e471ba76ef084e99bff87e9356d439d400f73de
67
66
2025-08-20T01:22:55Z
ARTIFICER
564804
Protected "[[Template:License/CC-BY-SA]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-SA
| icon = [[File:CC-BY-SA.svg|x50px|link=https://creativecommons.org/licenses/by-sa/3.0/|CC-BY-SA]]
| text = This file is under the [https://creativecommons.org/licenses/by-sa/3.0/ Creative Commons Attribution-ShareAlike 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-SA}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
1e471ba76ef084e99bff87e9356d439d400f73de
Template:License/fairuse
10
58
68
2025-08-20T01:22:56Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = fairuse
| darkIcon = yes
| icon = [[File:IN COPYRIGHT.svg|50px|link=https://rightsstatements.org/page/InC/1.0/?language=en|IN COPYRIGHT]]
| text = This file is copyrighted. It will be used in a way that qualifies as fair use under [https://en.wikipedia.org/wiki/Fair_use#Fair_use_under_United_States_law US copyright law].
}}</includeonly><noinclude>
This template currently looks like: {{License/fairuse}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
3662b685c4d9fa43d4f9342fae34b2f43ba925ef
69
68
2025-08-20T01:22:57Z
ARTIFICER
564804
Protected "[[Template:License/fairuse]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = fairuse
| darkIcon = yes
| icon = [[File:IN COPYRIGHT.svg|50px|link=https://rightsstatements.org/page/InC/1.0/?language=en|IN COPYRIGHT]]
| text = This file is copyrighted. It will be used in a way that qualifies as fair use under [https://en.wikipedia.org/wiki/Fair_use#Fair_use_under_United_States_law US copyright law].
}}</includeonly><noinclude>
This template currently looks like: {{License/fairuse}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
3662b685c4d9fa43d4f9342fae34b2f43ba925ef
Template:License
10
59
70
2025-08-20T01:22:57Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/{{{1|nolicense}}}|source={{{source|}}}}}</includeonly><noinclude>{{documentation}}</noinclude>
4b84fc940507f8fccb9c60b7f70b5a800a62fe59
71
70
2025-08-20T01:22:57Z
ARTIFICER
564804
Protected "[[Template:License]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/{{{1|nolicense}}}|source={{{source|}}}}}</includeonly><noinclude>{{documentation}}</noinclude>
4b84fc940507f8fccb9c60b7f70b5a800a62fe59
Template:License/CC-PD
10
60
72
2025-08-20T01:22:57Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-PD
| icon = [[File:CC-PD.svg|x50px|link=|Public Domain]]
| text = This file has been released into the public domain by the copyright holder, its copyright has expired, or it is ineligible for copyright. This applies worldwide.
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-PD}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
23b76ae521833f5a34f0bf73426a53aad8fa9923
73
72
2025-08-20T01:22:58Z
ARTIFICER
564804
Protected "[[Template:License/CC-PD]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-PD
| icon = [[File:CC-PD.svg|x50px|link=|Public Domain]]
| text = This file has been released into the public domain by the copyright holder, its copyright has expired, or it is ineligible for copyright. This applies worldwide.
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-PD}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
23b76ae521833f5a34f0bf73426a53aad8fa9923
Template:License/CC-SRR
10
61
74
2025-08-20T01:22:58Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-SRR
| icon = [[File:CC-SRR.svg|link=|CC-Some Rights Reserved]]
| text = This file is under the Creative Commons Some Rights Reserved License.
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-SRR}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
1ce36d04e501144e6a089ff194fee2b82732e85a
75
74
2025-08-20T01:22:59Z
ARTIFICER
564804
Protected "[[Template:License/CC-SRR]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-SRR
| icon = [[File:CC-SRR.svg|link=|CC-Some Rights Reserved]]
| text = This file is under the Creative Commons Some Rights Reserved License.
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-SRR}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
1ce36d04e501144e6a089ff194fee2b82732e85a
Template:License/CC-BY
10
62
76
2025-08-20T01:22:59Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY
| icon = [[File:CC-BY.svg|x50px|link=https://creativecommons.org/licenses/by/3.0/|CC-BY]]
| text = This file is under the [https://creativecommons.org/licenses/by/3.0/ Creative Commons Attribution 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
49f4317b802ef04c92f4edc474581035768c252e
77
76
2025-08-20T01:22:59Z
ARTIFICER
564804
Protected "[[Template:License/CC-BY]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY
| icon = [[File:CC-BY.svg|x50px|link=https://creativecommons.org/licenses/by/3.0/|CC-BY]]
| text = This file is under the [https://creativecommons.org/licenses/by/3.0/ Creative Commons Attribution 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
49f4317b802ef04c92f4edc474581035768c252e
Template:License/CC-BY-ND
10
63
78
2025-08-20T01:23:00Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-ND
| icon = [[File:CC-BY-ND.svg|x50px|link=https://creativecommons.org/licenses/by-nd/3.0/|CC-BY-ND]]
| text = This file is under the [https://creativecommons.org/licenses/by-nd/3.0/ Creative Commons Attribution-NoDerivs 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-ND}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
c77af748cb3aab2fce9bfd947149cb3e1ef0a3f0
79
78
2025-08-20T01:23:01Z
ARTIFICER
564804
Protected "[[Template:License/CC-BY-ND]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-ND
| icon = [[File:CC-BY-ND.svg|x50px|link=https://creativecommons.org/licenses/by-nd/3.0/|CC-BY-ND]]
| text = This file is under the [https://creativecommons.org/licenses/by-nd/3.0/ Creative Commons Attribution-NoDerivs 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-ND}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
c77af748cb3aab2fce9bfd947149cb3e1ef0a3f0
Template:License/game
10
64
80
2025-08-20T01:23:01Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:rightsholder|<!--
***************************************
***************************************
Step 1/2 [required]
Enter the name of the rightsholder, optionally with a link.
Example without link: indie.io
Example with a URL: [https://www.indie.io/ indie.io]
Edit on the line below this************-->
<!--Edit on the line above this********
***************************************
***************************************
-->}}<!--
continue to step 2
***************************************
***************************************
Step 2/2 [optional]
Enter the TOS link.
Example link: https://www.indie.io/terms-of-service
-->{{#vardefine:tos|<!--
Edit on the line below this************-->
<!--Edit on the line above this********
***************************************
***************************************
-->}}<!--
DON'T EDIT ANYTHING BELOW THIS
-->{{License/template
| source = {{{source|}}}
| type = developer
| darkIcon = yes
| icon = [[File:IN COPYRIGHT.svg|50px|link=https://rightsstatements.org/page/InC/1.0/?language=en|IN COPYRIGHT]]
| text = {{#if:{{#var:rightsholder}}|
<!-- Specific: -->This file is owned by {{#var:rightsholder}} and/or its licensors{{#if:{{#var:tos}}|, and is licensed under the {{#var:rightsholder}} [{{#var:tos}} Terms of Use]}}.<br/>All trademarks and registered trademarks present in the file are proprietary to {{#var:rightsholder}} and/or its licensors.
|
<!-- Generic: -->This file is owned by the applicable game studio and/or its licensors.
}}
}}</includeonly><noinclude>
This template currently looks like: {{License/game}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
f1283ce43eda0d523b8e1f249ebc02470d957b34
81
80
2025-08-20T01:23:01Z
ARTIFICER
564804
Protected "[[Template:License/game]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:rightsholder|<!--
***************************************
***************************************
Step 1/2 [required]
Enter the name of the rightsholder, optionally with a link.
Example without link: indie.io
Example with a URL: [https://www.indie.io/ indie.io]
Edit on the line below this************-->
<!--Edit on the line above this********
***************************************
***************************************
-->}}<!--
continue to step 2
***************************************
***************************************
Step 2/2 [optional]
Enter the TOS link.
Example link: https://www.indie.io/terms-of-service
-->{{#vardefine:tos|<!--
Edit on the line below this************-->
<!--Edit on the line above this********
***************************************
***************************************
-->}}<!--
DON'T EDIT ANYTHING BELOW THIS
-->{{License/template
| source = {{{source|}}}
| type = developer
| darkIcon = yes
| icon = [[File:IN COPYRIGHT.svg|50px|link=https://rightsstatements.org/page/InC/1.0/?language=en|IN COPYRIGHT]]
| text = {{#if:{{#var:rightsholder}}|
<!-- Specific: -->This file is owned by {{#var:rightsholder}} and/or its licensors{{#if:{{#var:tos}}|, and is licensed under the {{#var:rightsholder}} [{{#var:tos}} Terms of Use]}}.<br/>All trademarks and registered trademarks present in the file are proprietary to {{#var:rightsholder}} and/or its licensors.
|
<!-- Generic: -->This file is owned by the applicable game studio and/or its licensors.
}}
}}</includeonly><noinclude>
This template currently looks like: {{License/game}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
f1283ce43eda0d523b8e1f249ebc02470d957b34
Template:License/nolicense
10
65
82
2025-08-20T01:23:02Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = nolicense
| icon = [[File:Warning-red.svg|50px|link=|No license has been selected.]]
| text = Please select the proper license for this file by adding the proper parameter to <nowiki>{{License}}</nowiki>. See [[Template:License]] for details.
}}</includeonly><noinclude>
This template currently looks like: {{License/nolicense}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
9ddcfb97af577d7f8454e20f985b9456e7a95c77
83
82
2025-08-20T01:23:02Z
ARTIFICER
564804
Protected "[[Template:License/nolicense]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = nolicense
| icon = [[File:Warning-red.svg|50px|link=|No license has been selected.]]
| text = Please select the proper license for this file by adding the proper parameter to <nowiki>{{License}}</nowiki>. See [[Template:License]] for details.
}}</includeonly><noinclude>
This template currently looks like: {{License/nolicense}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
9ddcfb97af577d7f8454e20f985b9456e7a95c77
Template:License/CC-BY-NC
10
66
84
2025-08-20T01:23:02Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-NC
| icon = [[File:CC-BY-NC.svg|x50px|link=https://creativecommons.org/licenses/by-nc/3.0/|CC-BY-NC]]
| text = This file is under the [https://creativecommons.org/licenses/by-nc/3.0/ Creative Commons Attribution-NonCommercial 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-NC}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
535d8d725e53a0e8f94922ed597baed1353cec21
85
84
2025-08-20T01:23:03Z
ARTIFICER
564804
Protected "[[Template:License/CC-BY-NC]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-NC
| icon = [[File:CC-BY-NC.svg|x50px|link=https://creativecommons.org/licenses/by-nc/3.0/|CC-BY-NC]]
| text = This file is under the [https://creativecommons.org/licenses/by-nc/3.0/ Creative Commons Attribution-NonCommercial 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-NC}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
535d8d725e53a0e8f94922ed597baed1353cec21
Template:License/CC-BY-NC-SA
10
67
86
2025-08-20T01:23:03Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-NC-SA
| icon = [[File:CC-BY-NC-SA.svg|x50px|link=https://creativecommons.org/licenses/by-nc-sa/3.0/|CC-BY-NC-SA]]
| text = This file is under the [https://creativecommons.org/licenses/by-nc-sa/3.0/ Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-NC-SA}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
385fc8e61d98dd5ed6d4fa25b0eacf17cbca1218
87
86
2025-08-20T01:23:04Z
ARTIFICER
564804
Protected "[[Template:License/CC-BY-NC-SA]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC-BY-NC-SA
| icon = [[File:CC-BY-NC-SA.svg|x50px|link=https://creativecommons.org/licenses/by-nc-sa/3.0/|CC-BY-NC-SA]]
| text = This file is under the [https://creativecommons.org/licenses/by-nc-sa/3.0/ Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC-BY-NC-SA}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
385fc8e61d98dd5ed6d4fa25b0eacf17cbca1218
Template:License/CC0
10
68
88
2025-08-20T01:23:04Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC0
| icon = [[File:CC-0.svg|x50px|link=https://creativecommons.org/publicdomain/zero/1.0/|CC0]]
| text = This file is under the [https://creativecommons.org/publicdomain/zero/1.0/ CC0 1.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC0}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
a6ae218b1382bcbe6f0e6e98ef272e4355dd7205
89
88
2025-08-20T01:23:04Z
ARTIFICER
564804
Protected "[[Template:License/CC0]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = CC0
| icon = [[File:CC-0.svg|x50px|link=https://creativecommons.org/publicdomain/zero/1.0/|CC0]]
| text = This file is under the [https://creativecommons.org/publicdomain/zero/1.0/ CC0 1.0 License].
}}</includeonly><noinclude>
This template currently looks like: {{License/CC0}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
a6ae218b1382bcbe6f0e6e98ef272e4355dd7205
Template:License/doc
10
69
90
2025-08-20T01:23:04Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template is to be used under a ''Licensing'' heading on file pages to denote the file's license.
== Available licenses ==
=== Game ===
* Usage: <nowiki>{{License|game}}</nowiki>
{{License|game}}
=== Fairuse ===
* Usage: <nowiki>{{License|fairuse}}</nowiki>
{{License|fairuse}}
=== CC0 ===
* Usage: <nowiki>{{License|CC0}}</nowiki>
{{License|CC0}}
=== CC-BY-NC-ND ===
* Usage: <nowiki>{{License|CC-BY-NC-ND}}</nowiki>
{{License|CC-BY-NC-ND}}
=== CC-BY-NC-SA ===
* Usage: <nowiki>{{License|CC-BY-NC-SA}}</nowiki>
{{License|CC-BY-NC-SA}}
=== CC-BY-NC ===
* Usage: <nowiki>{{License|CC-BY-NC}}</nowiki>
{{License|CC-BY-NC}}
=== CC-BY-ND ===
* Usage: <nowiki>{{License|CC-BY-ND}}</nowiki>
{{License|CC-BY-ND}}
=== CC-BY-SA ===
* Usage: <nowiki>{{License|CC-BY-SA}}</nowiki>
{{License|CC-BY-SA}}
=== CC-BY ===
* Usage: <nowiki>{{License|CC-BY}}</nowiki>
{{License|CC-BY}}
=== CC-PD ===
* Usage: <nowiki>{{License|CC-PD}}</nowiki>
{{License|CC-PD}}
=== CC-SRR ===
* Usage: <nowiki>{{License|CC-SRR}}</nowiki>
{{License|CC-SRR}}
=== Permission ===
* Usage: <nowiki>{{License|permission}}</nowiki>
{{License|permission}}
=== No license ===
'''Providing no parameter (or invalid one) defaults to the nolicense notice:'''
<nowiki>{{License}}</nowiki>{{License}}
== Specifying source ==
'''Source parameter (optional):'''
The source parameter accepts a url to the source where the file came from if necessary for attribution.
Example:
<nowiki>{{License|game|source=https://indie.io/}}</nowiki>
{{License|game|source=https://indie.io/}}
<includeonly>
[[Category:License templates]]
</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
5b334ee591fa6a0867f5d8e685e580b5b6c21334
Template:License/Fairuse
10
70
91
2025-08-20T01:23:05Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:License/fairuse]]
ecb7db41961bb5256d571593ca3f90ae1e199a3e
Template:Clear
10
71
92
2025-08-20T01:23:05Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<div style="clear:{{{1|both}}};" class={{{class|}}}></div><noinclude>
{{documentation}}
</noinclude>
5b24b9fd5cc166a8c486e2422d5df465206ed39c
Template:Ml
10
72
93
2025-08-20T01:23:06Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<code>{{[[Module:{{{1}}}|{{{1}}}]]}}<sup>m</sup>{{#if:{{{2|}}}|.{{{2}}}()}}</code><noinclude>
* <code><nowiki>{{Ml|Infobox}}</nowiki></code> generates {{Ml|Infobox}}.
* <code><nowiki>{{Ml|ArgsUtil|merge}}</nowiki></code> generates {{Ml|ArgsUtil|merge}}.
[[Category:Formatting templates]]
</noinclude>
0c69bf8d7c3319f1cf2aa68f4b80261257291560
Template:(!
10
73
94
2025-08-20T01:23:07Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{|<noinclude>{{documentation}}</noinclude>
86e51fe1f06ae532410029eb39fa936d68880bc8
Template:!-
10
74
95
2025-08-20T01:23:07Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
|-<noinclude>{{documentation}}</noinclude>
636f9e440c24f4a3fe28b49cebd1808c3de8a814
Template:!)
10
75
96
2025-08-20T01:23:08Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
|}<noinclude>{{documentation}}</noinclude>
b2debea163716e114d1ea46e65a63d7a1ae84bc0
Template:(!/doc
10
76
97
2025-08-20T01:23:08Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:!-/doc
10
77
98
2025-08-20T01:23:09Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:!)/doc
10
78
99
2025-08-20T01:23:10Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:Pipe
10
79
100
2025-08-20T01:23:10Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
|<noinclude>{{documentation}}</noinclude>
9d1875aa686e4e25a0994448a39d057e91541788
Template:Pipe/doc
10
80
101
2025-08-20T01:23:11Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:!!
10
81
102
2025-08-20T01:23:12Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
||<noinclude>{{documentation}}</noinclude>
02fb31115eef5c15d6612ac334bf5a5d83155c0a
Template:!!/doc
10
82
103
2025-08-20T01:23:17Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:License/template
10
83
104
2025-08-20T01:23:17Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
--><div class="license {{{type|}}}" style="border: 1px solid var(--wiki-content-border-color); background: var(--wiki-content-background-color--secondary); align-items: center; padding: 5px; display: flex; gap: 1em;">
<div class="icon {{#if:{{{darkIcon|}}}|invert-on-dark}}">{{{icon|}}}</div>
<div class="text">{{{text|}}}{{#if:{{{source|}}}|<br/><span class="source">Source: {{{source|}}}</span>}}{{{text2|}}}</div>
</div><!--
--></includeonly><noinclude>{{documentation|Template:License/doc}}</noinclude>
7d0e694e6a42a5368b4b62ce6c01bfa2fb4e67b8
105
104
2025-08-20T01:23:18Z
ARTIFICER
564804
Protected "[[Template:License/template]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly><!--
--><div class="license {{{type|}}}" style="border: 1px solid var(--wiki-content-border-color); background: var(--wiki-content-background-color--secondary); align-items: center; padding: 5px; display: flex; gap: 1em;">
<div class="icon {{#if:{{{darkIcon|}}}|invert-on-dark}}">{{{icon|}}}</div>
<div class="text">{{{text|}}}{{#if:{{{source|}}}|<br/><span class="source">Source: {{{source|}}}</span>}}{{{text2|}}}</div>
</div><!--
--></includeonly><noinclude>{{documentation|Template:License/doc}}</noinclude>
7d0e694e6a42a5368b4b62ce6c01bfa2fb4e67b8
Template:*
10
84
106
2025-08-20T01:23:18Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
• <noinclude>
{{doc}}
[[Category:Formatting templates]]
</noinclude>
81a7f0051da7b8f4a0548d91c5eb429a974fac91
Template:*/doc
10
85
107
2025-08-20T01:23:19Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This is the '''bullet''' template; it looks like this: [ • ]
It works similarly to the HTML markup sequence: [<code>'''&nbsp;&bull;&nbsp;'''</code>], that is, a non-breaking space, a bullet and a non-breaking space.
This template is used when you want a larger bullet than a bold middot ['''·'''], but something smaller than an en dash [–].
<noinclude>[[Category:Template documentation]]</noinclude>
ea04fe63a10dc333ed9c48bfc397debb11682f1e
Template:Key
10
86
108
2025-08-20T01:23:20Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:platform | {{#if: {{{2|}}} | {{#switch: {{lc:{{{1|}}}}}
<!-- Desktop -->
|mouse
|keyboard=keyboard
<!-- Mobile -->
|gesture=gesture
<!-- Microsoft -->
|xboxseries
|xbox=Xbox
|xbox one
|xbone
|xbox1
|xboxone=xboxone
|xbox 360
|xb360
|xbox360
|360=360
<!-- Sony -->
|ps
|ps5
|playstation
|ds
|dualsense=DualSense
|playstation 4
|ps4=PS4
|playstation 3
|ps3=ps3
<!-- Nintendo -->
|ns
|switch=Switch
|wii=wii
}} | undefined }} }}<!--
-->{{#vardefine:key | {{#if: {{{2|}}} | {{ucfirst:{{{2}}}}} | {{ucfirst:{{{1}}}}} }} }}<!--
-->{{#vardefine:img | {{#if: {{{2|}}} | [[File:{{#var:platform}} {{#var:key}}.png|x25px|link=]] }} | Undefined }}<!--
--><span class="key">{{#var:img}}</span><!--
--></includeonly><!--
--><noinclude>{{doc}}</noinclude>
45576cb62a8104687b5b7ac26b042283c80ecae6
Template:Key/doc
10
87
109
2025-08-20T01:23:20Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<tabber>
|-|Desktop={{:Template:Key/doc/Keyboard}}
|-|Mobile={{:Template:Key/doc/Gesture}}
|-|Xbox={{:Template:Key/doc/Xbox}}
|-|DualSense={{:Template:Key/doc/DualSense}}
|-|PlayStation 4={{:Template:Key/doc/PS4}}
|-|Nintendo Switch={{:Template:Key/doc/Nintendo Switch}}
</tabber>
<noinclude>[[Category:Key template documentation]]</noinclude>
19eb9be1ca2c7112f63dd11c58d3888327dcca75
Template:Key/doc/Gesture
10
88
110
2025-08-20T01:23:21Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Images source: [[dev:Category:Gesture input images]]
=== Fingers ===
<code><nowiki>{{key|gesture|Finger Front}}</nowiki></code>
{{key|gesture|Finger Front}}
<code><nowiki>{{key|gesture|Finger Side}}</nowiki></code>
{{key|gesture|Finger Side}}
=== Tap & hold ===
<code><nowiki>{{key|gesture|Tap}}</nowiki></code>
{{key|gesture|Tap}}
<code><nowiki>{{key|gesture|Double Tap}}</nowiki></code>
{{key|gesture|Double Tap}}
<code><nowiki>{{key|gesture|Hold}}</nowiki></code>
{{key|gesture|Hold}}
=== Swipe motions ===
<code><nowiki>{{key|gesture|Swipe Bottom Left}}</nowiki></code>
{{key|gesture|Swipe Bottom Left}}
<code><nowiki>{{key|gesture|Swipe Bottom Right}}</nowiki></code>
{{key|gesture|Swipe Bottom Right}}
<code><nowiki>{{key|gesture|Swipe Down}}</nowiki></code>
{{key|gesture|Swipe Down}}
<code><nowiki>{{key|gesture|Swipe Left}}</nowiki></code>
{{key|gesture|Swipe Left}}
<code><nowiki>{{key|gesture|Swipe Right}}</nowiki></code>
{{key|gesture|Swipe Right}}
<code><nowiki>{{key|gesture|Swipe Top Left}}</nowiki></code>
{{key|gesture|Swipe Top Left}}
<code><nowiki>{{key|gesture|Swipe Top Right}}</nowiki></code>
{{key|gesture|Swipe Top Right}}
<code><nowiki>{{key|gesture|Swipe Up}}</nowiki></code>
{{key|gesture|Swipe Up}}
=== Zoom & scroll ===
<code><nowiki>{{key|gesture|Zoom In}}</nowiki></code>
{{key|gesture|Zoom In}}
<code><nowiki>{{key|gesture|Zoom Out}}</nowiki></code>
{{key|gesture|Zoom Out}}
<code><nowiki>{{key|gesture|Scroll Down}}</nowiki></code>
{{key|gesture|Scroll Down}}
<code><nowiki>{{key|gesture|Scroll Left}}</nowiki></code>
{{key|gesture|Scroll Left}}
<code><nowiki>{{key|gesture|Scroll Right}}</nowiki></code>
{{key|gesture|Scroll Right}}
<code><nowiki>{{key|gesture|Scroll Up}}</nowiki></code>
{{key|gesture|Scroll Up}}
=== Circular motions ===
<code><nowiki>{{key|gesture|Double Rotate}</nowiki></code>
{{key|gesture|Double Rotate}}
<code><nowiki>{{key|gesture|Full Circle}}</nowiki></code>
{{key|gesture|Full Circle}}
<code><nowiki>{{key|gesture|Half Circle}}</nowiki></code>
{{key|gesture|Half Circle}}
<code><nowiki>{{key|gesture|Quarter Circle}}</nowiki></code>
{{key|gesture|Quarter Circle}}
__NOTOC__
<noinclude>[[Category:Key template documentation]]</noinclude>
0a595b125cc6dbd6ad531c1e989d1929eaf1c6e2
Template:Key/doc/PS4
10
89
111
2025-08-20T01:23:21Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Images source: [[dev:Category:PS4 input images]]
=== D-pad & sticks ===
<code><nowiki>{{key|PS4|Dpad}}</nowiki></code>
{{key|PS4|Dpad}}
<code><nowiki>{{key|PS4|Left}}</nowiki></code>
{{key|PS4|Left}}
<code><nowiki>{{key|PS4|Right}}</nowiki></code>
{{key|PS4|Right}}
<code><nowiki>{{key|PS4|Up}}</nowiki></code>
{{key|PS4|Up}}
<code><nowiki>{{key|PS4|Down}}</nowiki></code>
{{key|PS4|Down}}
<code><nowiki>{{key|PS4|Left Stick}}</nowiki></code>
{{key|PS4|Left Stick}}
<code><nowiki>{{key|PS4|Right Stick}}</nowiki></code>
{{key|PS4|Right Stick}}
<code><nowiki>{{key|PS4|Touch Pad}}</nowiki></code>
{{key|PS4|Touch Pad}}
=== Front buttons ===
<code><nowiki>{{key|PS4|Circle}}</nowiki></code>
{{key|PS4|Circle}}
<code><nowiki>{{key|PS4|Cross}}</nowiki></code>
{{key|PS4|Cross}}
<code><nowiki>{{key|PS4|Square}}</nowiki></code>
{{key|PS4|Square}}
<code><nowiki>{{key|PS4|Triangle}}</nowiki></code>
{{key|PS4|Triangle}}
<code><nowiki>{{key|PS4|Share}}</nowiki></code>
{{key|PS4|Share}}
<code><nowiki>{{key|PS4|Options}}</nowiki></code>
{{key|PS4|Options}}
=== Rear buttons ===
<code><nowiki>{{key|PS4|L1}}</nowiki></code>
{{key|PS4|L1}}
<code><nowiki>{{key|PS4|R1}}</nowiki></code>
{{key|PS4|R1}}
<code><nowiki>{{key|PS4|L2}}</nowiki></code>
{{key|PS4|L2}}
<code><nowiki>{{key|PS4|R2}}</nowiki></code>
{{key|PS4|R2}}
<noinclude>[[Category:Key template documentation]]</noinclude>
1672e7f0dcd4db09545c96936cfbabcab681cfeb
Template:Key/doc/Nintendo Switch
10
90
112
2025-08-20T01:23:22Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Images source: [[dev:Category:Nintendo Switch input images]]
=== Nintendo Switch ===
<code><nowiki>{{Key|Switch|a}}</nowiki></code>
{{Key|Switch|a}}
<code><nowiki>{{Key|Switch|b}}</nowiki></code>
{{Key|Switch|b}}
<code><nowiki>{{Key|Switch|x}}</nowiki></code>
{{Key|Switch|x}}
<code><nowiki>{{Key|Switch|y}}</nowiki></code>
{{Key|Switch|y}}
<code><nowiki>{{Key|Switch|Left Stick}}</nowiki></code>
{{Key|Switch|Left Stick}}
<code><nowiki>{{Key|Switch|Right Stick}}</nowiki></code>
{{Key|Switch|Right Stick}}
<code><nowiki>{{Key|Switch|Left Stick Press}}</nowiki></code>
{{Key|Switch|Left Stick Press}}
<code><nowiki>{{Key|Switch|Right Stick Press}}</nowiki></code>
{{Key|Switch|Right Stick Press}}
<code><nowiki>{{Key|Switch|-}}</nowiki></code>
{{Key|Switch|-}}
<code><nowiki>{{Key|Switch|+}}</nowiki></code>
{{Key|Switch|+}}
<code><nowiki>{{Key|Switch|Capture}}</nowiki></code>
{{Key|Switch|Capture}}
<code><nowiki>{{Key|Switch|HOME}}</nowiki></code>
{{Key|Switch|HOME}}
<code><nowiki>{{Key|Switch|L}}</nowiki></code>
{{Key|Switch|L}}
<code><nowiki>{{Key|Switch|R}}</nowiki></code>
{{Key|Switch|R}}
<code><nowiki>{{Key|Switch|ZL}}</nowiki></code>
{{Key|Switch|ZL}}
<code><nowiki>{{Key|Switch|ZR}}</nowiki></code>
{{Key|Switch|ZR}}
=== Pro Controller ===
<code><nowiki>{{Key|Switch|Pro Control Pad}}</nowiki></code>
{{Key|Switch|Pro Control Pad}}
<code><nowiki>{{Key|Switch|Pro Control Pad Left}}</nowiki></code>
{{Key|Switch|Pro Control Pad Left}}
<code><nowiki>{{Key|Switch|Pro Control Pad Right}}</nowiki></code>
{{Key|Switch|Pro Control Pad Right}}
<code><nowiki>{{Key|Switch|Pro Control Pad Up}}</nowiki></code>
{{Key|Switch|Pro Control Pad Up}}
<code><nowiki>{{Key|Switch|Pro Control Pad Down}}</nowiki></code>
{{Key|Switch|Pro Control Pad Down}}
=== Joy-Con ===
<code><nowiki>{{Key|Switch|Directional Left}}</nowiki></code>
{{Key|Switch|Directional Left}}
<code><nowiki>{{Key|Switch|Directional Right}}</nowiki></code>
{{Key|Switch|Directional Right}}
<code><nowiki>{{Key|Switch|Directional Up}}</nowiki></code>
{{Key|Switch|Directional Up}}
<code><nowiki>{{Key|Switch|Directional Down}}</nowiki></code>
{{Key|Switch|Directional Down}}
==== Diagrams ====
<code><nowiki>{{Key|Switch|Joy-Con}}</nowiki></code>
{{Key|Switch|Joy-Con}}
<code><nowiki>{{Key|Switch|Joy-Con Separate}}</nowiki></code>
{{Key|Switch|Joy-Con Separate}}
<code><nowiki>{{Key|Switch|Joy-Con Left}}</nowiki></code>
{{Key|Switch|Joy-Con Left}}
<code><nowiki>{{Key|Switch|Joy-Con Right}}</nowiki></code>
{{Key|Switch|Joy-Con Right}}
__NOTOC__
<noinclude>[[Category:Key template documentation]]</noinclude>
34ef402e3bd539920ee4247d68882ecb53fc6eda
Template:Spoiler
10
91
113
2025-08-20T01:23:23Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
Base code written for Terraria Wiki: https://terraria.wiki.gg/wiki/Template:Spoiler
NOTE: This template needs a JavaScript function in MediaWiki:Common.js or MediaWiki:Vector.js to work, as well as styling in MediaWiki:Common.css or MediaWiki:Vector.css for the related classes
-->{{#vardefine:element|{{#if:{{{block|}}}|div|span}}}}<!--
-->{{#tag:{{#var:element}}|{{#tag:{{#var:element}}|{{{1|}}}}}|class=spoiler-content {{{class|}}}|id={{{id|}}}|style={{{css|{{{style|}}}}}} }}<!--
-->[[Category:Pages with spoilers]]<!--
--></includeonly><noinclude>
{{doc}}
[[Category:Formatting templates]]
</noinclude>
2da5f6bb4ec1204941f5ba21a2196cd35eccdb23
Template:Spoiler/doc
10
92
114
2025-08-20T01:23:24Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template is used to mark text and other elements as spoilers. Users can click or optionally hover to reveal their content.
== The hoverShowSpoilers gadget ==
Users can enable the <code>[[MediaWiki:Gadgets/hoverShowSpoilers|hoverShowSpoilers]]</code> gadget to make spoilers show on hover, not just on click. The code for this gadget can be found at [[MediaWiki:Gadgets/hoverShowSpoilers/main.css]].
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{spoiler|spoiler text}}</nowiki></code> (Click to toggle) || {{spoiler|spoiler text}}
|-
| <code><nowiki>{{spoiler|spoiler text with a [[Template:Navbox|link]]}}</nowiki></code> (Click to toggle) || {{spoiler|spoiler text with a [[Template:Navbox|link]]}}
|-
| <pre>
{{spoiler|block=y|Really long spoiler that spans multiple lines
It even has a bulleted list inside it:
* Item a
* Item b
* [[Special:Random|Item c]]
}}</pre>
|{{spoiler|block=y|Really long spoiler that spans multiple lines
It even has a bulleted list inside it:
* Item a
* Item b
* [[Special:Random|Item c]]
}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The <code>spoilers</code> gadget with JavaScript code for toggling the <code>.spoiler</code> class on/off on click:
** [[MediaWiki:Gadgets/spoilers]]
** [[MediaWiki:Gadgets/spoilers/main.js]]
* The <code>.spoiler-content</code> and any related classes, found in [[MediaWiki:Common.css]].
== Source ==
Base code adapted from [[wgg:terraria:Template:Spoiler|Template:Spoiler on Terraria Wiki]].
==TemplateData==
<templatedata>
{
"params": {
"1": {
"aliases": [
"text"
],
"label": "Text",
"description": "The text to be shown.",
"example": "Character A died during the battle.",
"type": "content",
"required": true
},
"hover": {
"label": "Show on Hover?",
"description": "Show spoiler text on mouse hover.",
"example": "hover=yes",
"type": "boolean",
"default": "hover=no"
},
"block": {
"label": "Display as block?",
"description": "If given, display the spoiler as a block instead of inline. Useful for long spoilers spanning multiple lines or using block-level elements like lists.",
"example": "y",
"type": "boolean",
"suggested": true
},
"class": {
"label": "Class",
"description": "A class or classes to apply to the spoiler",
"type": "string"
},
"id": {
"label": "ID",
"description": "A CSS ID to apply to the spoiler.",
"type": "string"
},
"style": {
"description": "Inline CSS styles to pass in.",
"type": "string",
"aliases": [
"css"
],
"label": "Style"
}
},
"description": "This template can be used to mark text as a spoiler.",
"maps": {
"1": {}
},
"paramOrder": [
"1",
"hover",
"block",
"class",
"id",
"style"
],
"format": "inline"
}
</templatedata>
<noinclude>[[Category:Template documentation]]</noinclude>
bae231a84e57129ec12ba47e554ed42e76c185e0
Template:Link icon
10
93
115
2025-08-20T01:23:24Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#vardefine:target|{{{1|}}}<!-- end vd -->}}<!--
-->{{#vardefine:display|{{#if:{{{2|}}}|{{{2}}}|{{{1}}}<!-- end if -->}}<!-- end vd -->}}<!--
-->{{#vardefine:iconSize|1.2em}}<!--
-->{{#vardefine:lineHeight|1lh}}<!--
-->{{#vardefine:fileExists|{{filepath:{{#var:target}} ({{{type}}}).png}}}}<!--
-->{{#ifeq: {{{2|}}} | notext <!-- start if notext
-->|<span class="link-icon notext" style="--link-icon-size: {{#var:iconSize}}; --link-icon-line-height: {{#var:lineHeight}};"><!-- start notext icon element
-->{{#if: {{#var:fileExists}} <!-- start icon if
-->| <span class="regular">[[File:{{#var:target}} ({{{type}}}).png|link={{#var:target}}|alt=]]</span><!-- end regular icon
-->| <span class="fallback">[[File:{{{1}}} ({{{type}}}).png|?]]</span><!-- end fallback icon (?)
-->}}<!-- end icon if
--></span><!-- end notext icon
-->|<span class="link-icon" style="--link-icon-size: {{#var:iconSize}}; --link-icon-line-height: {{#var:lineHeight}};"><!-- start icon + text element
-->{{#if: {{#var:fileExists}} <!-- start icon if
-->| <span class="regular">[[File:{{#var:target}} ({{{type}}}).png|link={{#var:target}}|alt=]]</span><!-- end regular icon
-->| <span class="fallback">[[File:{{{1}}} ({{{type}}}).png|?]]</span><!-- end fallback icon (?)
-->}} <!-- end icon if
--><span class="display-text">[[{{#var:target}}|{{#var:display}}]]</span><!-- end display text
--></span> <!-- end icon + text element
-->}}<!-- end if notext
--></includeonly><noinclude>{{Documentation}}[[Category:Formatting templates]]</noinclude>
a8fc86aa3dc0f0085e5d1236a47e8d04e8685684
Template:Link icon/doc
10
94
116
2025-08-20T01:23:25Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{No direct use}}
== List of link icon templates ==
* {{tl|Character icon}}
* {{tl|Item icon}}
== Dependencies==
For this template to work properly, you need the following:
* The <code>.link-icon</code> class and any related classes, found in [[MediaWiki:Common.css]].
<noinclude>[[Category:Template documentation]]</noinclude>
654dfb540ea31a810ef53c3820862942e63b2e8a
Template:I
10
95
117
2025-08-20T01:23:25Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Link icon]]
6ebdedb4de95efaa3e6ca27590e79aca674f2364
Template:Quote
10
96
118
2025-08-20T01:23:26Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
--><div class="quote"><!-- start quote wrapper
--><div class="marks-wrapper"><!-- start marks wrapper
--><div class="block"><!-- start quote block
-->{{#if:{{{title|}}}|<div class="title">{{{title}}}</div>|}}<!--
-->{{#if:{{{text|{{{1|}}}}}}|<div class="text">{{{text|{{{1|}}}}}}</div>|}}<!--
--></div><!-- end quote block
--></div><!-- end marks wrapper
-->{{#if:{{{author|{{{2|}}}}}}|<div class="author">― {{#if:{{{authorpage|}}}| [[{{{authorpage}}}|{{{author|{{{2|}}}}}}]] | {{{author|{{{2|}}}}}} }}</div>|}}<!--
--></div><!--
-->[[Category:Pages with quotes]]</includeonly><noinclude>{{Documentation}}[[Category:Formatting templates]]</noinclude>
095258ceee92819a4e7b83c26fba3761bf9c41a9
Template:Item icon
10
97
119
2025-08-20T01:23:26Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Link icon|{{{1|}}}|{{{2|}}}|type=Item}}</includeonly><noinclude>{{documentation}}[[Category:Formatting templates]]</noinclude>
6564279e3808e659b8034ad4b96f4f9e9e498b57
Template:Item icon/doc
10
98
120
2025-08-20T01:23:27Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
== Summary ==
<templatedata>
{
"params": {
"1": {
"aliases": [
"page"
],
"label": "Page Name",
"description": "The name for the target page.",
"example": "Page Name",
"type": "wiki-page-name",
"required": true
},
"2": {
"aliases": [
"label"
],
"label": "Link Label",
"description": "The text to the be displayed on the link icon's label.",
"example": "Alternative Page Name",
"type": "line"
}
},
"description": "Use this template to display an icon next to a page link.\n\nThis template assumes that each page has an icon uploaded at a specific location, namely \"File:Page Name (Item).png\".",
"format": "inline"
}
</templatedata>
== Examples ==
For the examples below, <code><nowiki>File:Mystic Feather (Item).png</nowiki></code> was used as the icon for a page called <code>Mystic Feather</code>.
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Item icon|Mystic Feather}}</nowiki></code> || {{Item icon|Mystic Feather}}
|-
| <code><nowiki>{{Item icon|Mystic Feather|Mystic Feathers}}</nowiki></code> || {{Item icon|Mystic Feather|Mystic Feathers}}
|-
| <code><nowiki>{{Item icon|Mystic Feather|notext}}</nowiki></code> || {{Item icon|Mystic Feather|notext}}
|-
| <code><nowiki>{{Item icon|Missing Item}}</nowiki></code> (Missing Page Icon) || {{Item icon|Missing Item}}
|}
== Dependencies==
For this template to work properly, you need the following:
* The base {{tl|Link icon}} template.
* The <code>.link-icon</code> class and any related classes, found in [[MediaWiki:Common.css]].
4dfcab6f3d3c88596068607685645f29666f0141
Template:Character icon
10
99
121
2025-08-20T01:23:28Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Link icon|{{{1|}}}|{{{2|}}}|type=Character}}</includeonly><noinclude>{{documentation}}[[Category:Formatting templates]]</noinclude>
24bad84fd5dea93cab210dfd592fda86af09eb87
Template:Character icon/doc
10
100
122
2025-08-20T01:23:28Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
== Summary ==
<templatedata>
{
"params": {
"1": {
"aliases": [
"page"
],
"label": "Page Name",
"description": "The name for the target page.",
"example": "Page Name",
"type": "wiki-page-name",
"required": true
},
"2": {
"aliases": [
"label"
],
"label": "Link Label",
"description": "The text to the be displayed on the link icon's label.",
"example": "Alternative Page Name",
"type": "line"
}
},
"description": "Use this template to display an icon next to a page link.\n\nThis template assumes that each page has an icon uploaded at a specific location, namely \"File:Page Name (Character).png\".",
"format": "inline"
}
</templatedata>
== Examples ==
For the examples below, <code><nowiki>File:Invisible Boy (Character).png</nowiki></code> was used as the icon for a page called <code>Invisible Boy</code>.
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Character icon|Invisible Boy}}</nowiki></code> || {{Character icon|Invisible Boy}}
|-
| <code><nowiki>{{Character icon|Invisible Boy|The Invisible Boy}}</nowiki></code> || {{Character icon|Invisible Boy|The Invisible Boy}}
|-
| <code><nowiki>{{Character icon|Invisible Boy|notext}}</nowiki></code> || {{Character icon|Invisible Boy|notext}}
|-
| <code><nowiki>{{Character icon|Missing Boy}}</nowiki></code> (Missing Page Icon) || {{Character icon|Missing Boy}}
|}
== Dependencies==
For this template to work properly, you need the following:
* The base {{tl|Link icon}} template.
* The <code>.link-icon</code> class and any related classes, found in [[MediaWiki:Common.css]].
0999a706143c16f5ed970816e7825239cfce9547
Template:Quote/doc
10
101
123
2025-08-20T01:23:29Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <pre>{{Quote|text=Now is the winter of our discontent made glorious summer by this sun of York}}</pre>
| {{Quote|text=Now is the winter of our discontent made glorious summer by this sun of York}}
|-
| <pre>{{Quote
|title=Opening lines of ''Richard III''
|text=Now is the winter of our discontent made glorious summer by this sun of York}}</pre>
| {{Quote
|title=Opening lines of ''Richard III''
|text=Now is the winter of our discontent made glorious summer by this sun of York}}
|-
| <pre>{{Quote
|title=Opening lines of ''Richard III''
|author=William Shakespeare
|text=Now is the winter of our discontent made glorious summer by this sun of York}}</pre>
| {{Quote
|title=Opening lines of ''Richard III''
|author=William Shakespeare
|text=Now is the winter of our discontent made glorious summer by this sun of York}}
|-
| <pre>{{Quote
|title=Opening lines of ''Richard III''
|author=William Shakespeare
|authorpage=wikipedia:William Shakespeare
|text=Now is the winter of our discontent made glorious summer by this sun of York}}</pre>
| {{Quote
|title=Opening lines of ''Richard III''
|author=William Shakespeare
|authorpage=wikipedia:William Shakespeare
|text=Now is the winter of our discontent made glorious summer by this sun of York}}
|-
| <pre>{{Quote
|author=William Shakespeare
|authorpage=wikipedia:William Shakespeare
|text=Now is the winter of our discontent made glorious summer by this sun of York}}</pre>
| {{Quote
|author=William Shakespeare
|authorpage=wikipedia:William Shakespeare
|text=Now is the winter of our discontent made glorious summer by this sun of York}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The <code>.quote</code> and any related classes, found in [[MediaWiki:Common.css]].
<noinclude>[[Category:Template documentation]]</noinclude>
== Template data (for Visual Editor) ==
<templatedata>
{
"params": {
"title": {
"label": "Title",
"description": "If the quote has a title, put it here.",
"example": "Richard III's soliloquy",
"type": "line"
},
"text": {
"label": "Quoted Text",
"description": "The quoted text to be displayed.",
"example": "Now is the winter of our discontent made glorious summer by this sun of York",
"type": "string",
"required": true
},
"author": {
"label": "Quote's Author",
"description": "The author of the displayed quote.",
"example": "William Shakespeare",
"type": "line",
"suggested": true
},
"authorpage": {
"label": "Author's Page",
"description": "If the quote's author has a page on the Wiki, put the page name here.",
"example": "William Shakespeare (playwright)",
"type": "wiki-page-name",
"suggested": true
}
},
"description": "This template creates a styled block element for quotes.",
"paramOrder": [
"text",
"author",
"authorpage",
"title"
],
"format": "block"
}
</templatedata>
8a10e77de70ff704435282ce0f2ba792a13404a5
Template:Hatnote
10
102
124
2025-08-20T01:23:29Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->[[Category:Pages with hatnotes]]<!--
--><div class="hatnote {{#if:{{{icon|}}}|icon}} noexcerpt">{{#if:{{{icon|}}}|[[File:{{{icon}}}|x22px]]<nowiki> </nowiki>}}{{{1|}}}</div><!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Hatnote templates| ]]</noinclude>
7d46b899835bfd29a8fbee088499bc7a6acb2587
Template:Hatnote/doc
10
103
125
2025-08-20T01:23:30Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{No direct use}}
== List of hatnote templates ==
* {{tl|Disambiguation}}
* {{tl|Distinguish}}
* {{tl|For}}
* {{tl|Main}}
== Dependencies ==
For this template to work properly, you need the following:
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
* The <code>--wiki-content-border-color--secondary</code> CSS variable, defined in [[MediaWiki:Common.css]].
<noinclude>[[Category:Template documentation]]</noinclude>
464f2f866befaf4cfa47f68ab0ad4f170c13463d
Template:Disambiguation (wiki.gg)/doc
10
104
126
2025-08-20T01:23:31Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Disambiguation Page",
"description": "A custom disambiguation page name.",
"example": "Disambiguation Page",
"type": "wiki-page-name"
},
"2": {
"label": "Link Label",
"description": "A label for the custom disambiguation page.",
"example": "Alternative Page Name",
"type": "line"
},
"topic": {
"label": "Custom Topic",
"description": "In case {{PAGENAME}} does not describe the topic, this can be used to display a custom topic",
"example": "a custom topic",
"default": "{{PAGENAME}}",
"type": "line"
}
},
"description": "This hatnote template is meant to be used at the top of an article to indicate the existence of a disambiguation page.",
"paramOrder": [
"1",
"2",
"topic"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Disambiguation}}</nowiki></code> || {{Disambiguation|topic=Example}}
|-
| <code><nowiki>{{Disambiguation|Special:Random|topic=Example}}</nowiki></code> || {{Disambiguation|Special:Random|topic=Example}}
|-
| <code><nowiki>{{Disambiguation|Special:Random|Page Label|topic=this particular topic}}</nowiki></code> || {{Disambiguation|Special:Random|Page Label|topic=this particular topic}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The {{tl|Hatnote}} base template.
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
== Source ==
Roughly based on [[wikipedia:Template:About|Wikipedia's About Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
5fce9c689120c57454571ff0e60a2cd447df5713
Template:Disambiguation (wiki.gg)
10
105
127
2025-08-20T01:23:31Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:topic|<!-- start vd
-->{{#if:{{{topic|}}} | {{{topic}}} | {{PAGENAME}} }}<!-- end if
-->}}<!-- end vd
-->{{#vardefine:disambig|<!-- start vd
-->{{#if:{{{1|}}}<!-- start custom disambig if
-->|{{{1}}}<!-- start label if -->{{#if:{{{2|}}} | {{!}}{{{2}}} }}<!-- end label if
-->|{{#var:topic}} (disambiguation)<!-- else; use regular disambig
-->}}<!-- end custom disambig if
-->}}<!-- end vd
-->{{Hatnote|<!--
-->This page is about '''{{#var:topic}}'''. For other uses, see [[{{#var:disambig}}]].<!--
-->|icon=Disambig.svg<!--
-->}}<!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Hatnote templates]]</noinclude>
c4c62e7a1876492eb970ea182cf4ac0bcad97913
Template:Distinguish
10
106
128
2025-08-20T01:23:32Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:text|<!-- start vd
-->{{#if:{{{text|}}} | {{{text}}} |<!-- start top if
-->{{#if:{{{2|}}}<!-- if more than one page
-->|[[{{{1}}}]]{{#if:{{{3|}}}<!-- start concat if
-->|, [[{{{2}}}]] or [[{{{3}}}]]<!-- concat two
-->|<nowiki> </nowiki>or [[{{{2}}}]]<!-- else; concat one
-->}}<!-- end concat if
-->|[[{{{1}}}]]<!-- else; one page only
-->}}<!-- end custom disambig if
-->}}<!-- end if
-->}}<!-- end vd
-->{{Hatnote|<!--
-->Not to be confused with {{#var:text}}.<!--
-->}}<!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Hatnote templates]]</noinclude>
67ae5406ffd29bec56cfe7ad6527bb09a9733496
Template:Distinguish/doc
10
107
129
2025-08-20T01:23:32Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Alternative",
"description": "The alternative page.",
"example": "Alternative Page",
"type": "wiki-page-name",
"suggested": true
},
"2": {
"label": "Second Alternative",
"description": "A second alternative page.",
"example": "Second Alternative Page",
"type": "wiki-page-name"
},
"3": {
"label": "Third Alternative",
"description": "A third alternative page.",
"example": "Third Alternative Page",
"type": "wiki-page-name"
},
"text": {
"label": "Alternative Text",
"description": "Instead of using pages, you can provide a full alternative text. This parameter overrides other provided parameters.",
"example": "the alternative page, [[Alternative Page]]",
"type": "line"
}
},
"description": "This hatnote template is meant to be used to indicate possible alternatives to what the reader wants to find.",
"paramOrder": [
"1",
"2",
"3",
"text"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Distinguish|Special:Uncategorizedpages}}</nowiki></code> || {{Distinguish|Special:Uncategorizedpages}}
|-
| <code><nowiki>{{Distinguish|Special:Uncategorizedpages|Special:Uncategorizedfiles}}</nowiki></code> || {{Distinguish|Special:Uncategorizedpages|Special:Uncategorizedfiles}}
|-
| <code><nowiki>{{Distinguish|Special:Uncategorizedpages|Special:Uncategorizedfiles|Special:Uncategorizedcategories}}</nowiki></code> || {{Distinguish|Special:Uncategorizedpages|Special:Uncategorizedfiles|Special:Uncategorizedcategories}}
|-
| <code><nowiki>{{Distinguish|Special:Uncategorizedpages{{!}}Page 1}}</nowiki></code> (Custom link label) || {{Distinguish|Special:Uncategorizedpages{{!}}Page 1}}
|-
| <code><nowiki>{{Distinguish|text = Page 1, another name for [[Special:Uncategorizedpages]]}}</nowiki></code> || {{Distinguish|text = Page 1, another name for [[Special:Uncategorizedpages]]}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The {{tl|Hatnote}} base template.
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
== Source ==
Roughly based on [[wikipedia:Template:Distinguish|Wikipedia's Distinguish Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
2a06ed576ae6479add20834628f9378c657cb4fb
Template:For
10
108
130
2025-08-20T01:23:33Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:text|<!-- start vd
-->{{#if:{{{3|}}}<!-- if more than one page
-->|[[{{{2}}}]]{{#if:{{{4|}}}<!-- start concat if
-->|, [[{{{3}}}]] and [[{{{4}}}]]<!-- concat two
-->|<nowiki> </nowiki>and [[{{{3}}}]]<!-- else; concat one
-->}}<!-- end concat if
-->|[[{{{2}}}]]<!-- else; one page only
-->}}<!-- end if
-->}}<!-- end vd
-->{{Hatnote|<!--
-->For {{{1}}}, see {{#var:text}}.<!--
-->}}<!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Hatnote templates]]</noinclude>
1899e48855153617f7c0bf3087b781bc80f0395c
Template:For/doc
10
109
131
2025-08-20T01:23:34Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Topic",
"description": "The topic the following pages are about.",
"example": "more information",
"type": "line",
"required": true
},
"2": {
"label": "Related Page",
"description": "A related page.",
"example": "Related Page",
"type": "wiki-page-name",
"required": true
},
"3": {
"label": "Second Page",
"description": "A second related page.",
"example": "Second Related Page",
"type": "wiki-page-name"
},
"4": {
"label": "Third Page",
"description": "A third related page.",
"example": "Third Related Page",
"type": "wiki-page-name"
}
},
"description": "This hatnote template is meant to be used to show pages related to a topic the reader might want to visit.",
"paramOrder": [
"1",
"2",
"3",
"4"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{For|more information|Special:WantedPages}}</nowiki></code> || {{For|more information|Special:WantedPages}}
|-
| <code><nowiki>{{For|more information|Special:WantedPages|Special:UncategorizedPages}}</nowiki></code> || {{For|more information|Special:WantedPages|Special:UncategorizedPages}}
|-
| <code><nowiki>{{For|more information|Special:WantedPages|Special:UncategorizedPages|Special:UncategorizedCategories}}</nowiki></code> || {{For|more information|Special:WantedPages|Special:UncategorizedPages|Special:UncategorizedCategories}}
|-
| <code><nowiki>{{For|more information|Special:WantedPages{{!}}Page 1}}</nowiki></code> (Custom link label) || {{For|more information|Special:WantedPages{{!}}Page 1}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The {{tl|Hatnote}} base template.
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
== Source ==
Roughly based on [[wikipedia:Template:For|Wikipedia's For Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
b2a30a9bf8acff259d5e86654a2de69c2d5e4fff
Template:Main
10
110
132
2025-08-20T01:23:34Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:text|<!-- start vd
-->{{#if:{{{2|}}}<!-- if more than one page
-->|[[{{{1}}}]]{{#if:{{{3|}}}<!-- start concat if
-->|, [[{{{2}}}]] and [[{{{3}}}]]<!-- concat two
-->|<nowiki> </nowiki>and [[{{{2}}}]]<!-- else; concat one
-->}}<!-- end concat if
-->|[[{{{1}}}]]<!-- else; one page only
-->}}<!-- end if
-->}}<!-- end vd
-->{{Hatnote|<!--
-->{{#if:{{{2|}}}|Main articles|Main article}}: {{#var:text}}<!--
-->}}<!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Hatnote templates]]</noinclude>
e02ac04db1bbce6b71a9aa8a5064182f662d8470
Template:Main/doc
10
111
133
2025-08-20T01:23:35Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Article",
"description": "A main article.",
"example": "Article",
"type": "wiki-page-name",
"required": true
},
"2": {
"label": "Second Article",
"description": "A second main article.",
"example": "Second Article",
"type": "wiki-page-name"
},
"3": {
"label": "Third Article",
"description": "A third main article.",
"example": "Third Article",
"type": "wiki-page-name"
}
},
"description": "This hatnote template is meant to be in sections of an article mentioning information about another existing main article.",
"paramOrder": [
"1",
"2",
"3"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Main|Special:WantedPages}}</nowiki></code> || {{Main|Special:WantedPages}}
|-
| <code><nowiki>{{Main|Special:WantedPages#Section Title}}</nowiki></code> || {{Main|Special:WantedPages#Section Title}}
|-
| <code><nowiki>{{Main|Special:WantedPages|Special:UncategorizedPages}}</nowiki></code> || {{Main|Special:WantedPages|Special:UncategorizedPages}}
|-
| <code><nowiki>{{Main|Special:WantedPages|Special:UncategorizedPages|Special:UncategorizedCategories}}</nowiki></code> || {{Main|Special:WantedPages|Special:UncategorizedPages|Special:UncategorizedCategories}}
|-
| <code><nowiki>{{Main|Special:WantedPages{{!}}Page 1}}</nowiki></code> (Custom link label) || {{Main|Special:WantedPages{{!}}Page 1}}
|}
== Dependencies ==
This template requires the {{tl|Hatnote}} metatemplate.
== Source ==
Roughly based on [[wikipedia:Template:For|Wikipedia's For Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
dd762adeece0f944821cb81ee14a8bd9cb539b22
Template:Ambox/doc
10
112
134
2025-08-20T01:23:35Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{#ifeq:{{ROOTPAGENAME}}|Ambox|"Ambox" is an abbreviation for '''A'''rticle '''m'''essage '''box'''. You can use amboxes in articles to indicate something important about the current page, often in the header.|
This '''message template''' is an [[Template:Ambox|article message box]], or '''ambox'''. The documentation below discusses how to use each ambox provided by the wiki.
}}
== Premade amboxes ==
=== Problem notice amboxes ===
These amboxes are used temporarily to notify other editors and visitors about a problem with an article. These amboxes support the following parameters:
* <code>|tiny=</code>: If set to <code>yes</code>, the box will have less padding and the icon will be much smaller than default.
* <code>|class=</code>: Any additional CSS classes to add to the ambox container element.
* <code>|date=</code>: The date the ambox was added to the page.
* <code>|nocat=</code>: If set to <code>yes</code>, no category will be added to the page. Use this only when creating documentation.
'''Note:''' Premade amboxes need the base {{tl|Ambox}} template to work.
{| class="wikitable"
! Code !! Result
|-
| {{tl|Cleanup}} || {{Cleanup|nocat=yes}}
|-
| {{tl|Delete}} || {{Delete|nocat=yes}}
|-
| {{tl|Merge|Example}} || {{Merge|Template:Ambox{{!}}Example|nocat=yes}}
|-
| {{tl|Move|Example}} || {{Move|Template:Ambox{{!}}Example|nocat=yes}}
|-
| {{tl|Split|Example}}<br/>{{tl|Split|Example 1|Example 2|Example 3}} || {{Split|Template:Ambox{{!}}Example|nocat=yes}}
{{Split|Template:Ambox{{!}}Example 1|Template:Ambox{{!}}Example 2|Template:Ambox{{!}}Example 3|nocat=yes}}
|-
| {{tl|Stub}} || {{Stub|nocat=yes}}
|-
|}
=== Informational amboxes ===
These amboxes are intended as permanent fixtures to a page, to notify visitors about some piece of information relevant to the page. These amboxes support the following parameters in addition to any listed:
* <code>|tiny=</code>: If set to <code>yes</code>, the box will have less padding and the icon will be much smaller than default.
* <code>|class=</code>: Any additional CSS classes to add to the ambox container element.
{| class="wikitable"
! Code !! Additional parameters !! Result
|-
| {{tl|Spoiler warning}} || || {{Spoiler warning|nocat=yes}}
|-
| {{tl|No direct use}} || || {{No direct use|nocat=yes}}
|-
| {{tl|Uses Lua}} || <code><nowiki>|1=</nowiki></code>, a comma-separated list of modules used || {{Uses Lua|nocat=yes}}
|}
=== Optional parameters ===
You can use optional parameters to further customize a premade ambox. The example below is using <code>tiny=yes</code> and <code>date=01/01/2021</code>.
{{Cleanup|tiny=yes|date=01/01/2021|nocat=yes}}
== Creating a custom ambox ==
You can create additional ambox templates as needed using the following parameters:
<pre>
{{Ambox
| color = The left border color.
| icon = The icon image to be displayed.
| title = The optional title.
| message = The explanation text displayed.
| tiny = If you want the tiny version of the ambox, fill the parameter with "yes".
| date = An optional date of creation for the message.
| class = An optional CSS class for the ambox.
}}
</pre>
== Dependencies ==
For this template to work properly, you need the following:
* <code>.ambox</code> and any related classes, found in [[MediaWiki:Common.css]].
<includeonly>[[Category:Notice templates]]</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
d4fda481c06177d59ff39364bf17e15d7f1adfbc
Template:Cleanup
10
113
135
2025-08-20T01:23:36Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = gold
| icon = Cleanup.svg
| message = This page does not meet '''{{SITENAME}}'''<nowiki/>'s page quality standards. You can [{{fullurl:{{FULLPAGENAME}}|action=edit}} edit it] to help fix grammar, formatting, or code issues.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{#ifeq: {{lc:{{{nocat|}}}}} | yes ||[[Category:Pages in need of improvement]]}}</includeonly><!--
--><noinclude>{{Cleanup|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
9c9fb940d733227f74a7ce12720d22f569bd4d3e
Template:Delete
10
114
136
2025-08-20T01:23:37Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = grey
| icon = Delete.svg
| title = Candidate for Deletion
| message = This page lacks relevance for '''{{SITENAME}}''' and is a candidate for '''deletion'''.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{#ifeq: {{lc:{{{nocat|}}}}} | yes ||[[Category:Candidates for deletion]]}}</includeonly><!--
--><noinclude>{{Delete|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
6c827de94518d7f5f1635b13425be0d0fb4078da
Template:No direct use
10
115
137
2025-08-20T01:23:37Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{ambox|icon=Warning-red.svg|title=Don't call this template directly from any content page!
|message=This template is intended to be used inside of another template. Then that template in turn may be used on content pages.
|color=red
|tiny={{{tiny|}}}
|class={{{class|}}}
}}</includeonly><noinclude>{{doc|Template:Ambox/doc}}
[[Category:Notice templates]]</noinclude>
22c9c1b0d6c05220eb6d7ad84073f7d878b60b68
Template:UsesLua
10
116
138
2025-08-20T01:23:38Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Uses Lua]]
9675a92267565619bc6418ec4e88163985302408
Template:Cleanup/doc
10
117
139
2025-08-20T01:23:39Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Delete/doc
10
118
140
2025-08-20T01:23:40Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Spoiler warning
10
119
141
2025-08-20T01:23:40Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Ambox
| color = red
| icon = Warning-red.svg
| title = Spoiler Warning
| message = This page contains '''spoilers'''. View at your own discretion.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
}}<noinclude>{{doc|Template:Ambox/doc}}</noinclude>
d46344bae30adce89ead1cf12e8c3ff904e95203
Template:Spoiler warning/doc
10
120
142
2025-08-20T01:23:41Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Uses Lua/doc
10
121
143
2025-08-20T01:23:42Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Stub
10
122
144
2025-08-20T01:23:42Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = gold
| icon = Stub.svg
| message = This page is a [[support:Stub|stub]]. You can help '''{{SITENAME}}''' by [{{fullurl:{{FULLPAGENAME}}|action=edit}} expanding it].
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{#ifeq: {{lc:{{{nocat|}}}}} | yes ||[[Category:Stubs]]}}</includeonly><!--
--><noinclude>{{Stub|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
1effeb7d6eb04a0b11c76b8bfa871703461c9344
Template:Stub/doc
10
123
145
2025-08-20T01:23:43Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:Ambox/doc]]
68bfb03f8f28c95443c7b1997f252c236bf87256
Template:NoDirectUse
10
124
146
2025-08-20T01:23:43Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:No direct use]]
8448af1f61f0d64a84806b006c70670d9296acde
Template:No direct use/doc
10
125
147
2025-08-20T01:23:44Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:Ambox/doc]]
68bfb03f8f28c95443c7b1997f252c236bf87256
Template:Merge
10
126
148
2025-08-20T01:23:44Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = purple
| icon = Merge.svg
| message = It has been proposed that this page be [[support:Merge|merged]] with [[{{{1}}}]].
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{#ifeq: {{lc:{{{nocat|}}}}} | yes ||[[Category:Candidates for merging]]}}</includeonly><!--
--><noinclude>{{Merge|Template:Merge|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
9975c110e793cc1943eac9ea8e62257d704ab853
Template:Merge/doc
10
127
149
2025-08-20T01:23:45Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Move
10
128
150
2025-08-20T01:23:46Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = darkorange
| icon = Move.svg
| message = It has been proposed that this page be moved to [[{{{1}}}]].
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{#ifeq: {{lc:{{{nocat|}}}}} | yes ||[[Category:Candidates for moving]]}}</includeonly><!--
--><noinclude>{{Move|Template:Ambox{{!}}Example|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
dc4fd9090208e453457d6d2df193b9a7ee3b562d
Template:Move/doc
10
129
151
2025-08-20T01:23:47Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Split
10
130
152
2025-08-20T01:23:47Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:pages|<!-- start vd
-->{{#if:{{{2|}}}<!-- if more than one page
-->|new pages titled [[{{{1}}}]]{{#if:{{{3|}}}<!-- start concat if
-->|, [[{{{2}}}]] and [[{{{3}}}]]<!-- concat two
-->|<nowiki> </nowiki>and [[{{{2}}}]]<!-- else; concat one
-->}}<!-- end concat if
-->|a new page titled [[{{{1}}}]]<!-- else; one page only
-->}}<!-- end if
-->}}<!-- end vd
-->{{Ambox
| color = purple
| icon = Split.svg
| message = It has been proposed that this page be split into {{#var:pages}}.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{#ifeq: {{lc:{{{nocat|}}}}} | yes ||[[Category:Candidates for splitting]]}}</includeonly><!--
--><noinclude>{{Split|Template:Ambox{{!}}Example|nocat=yes}}
{{Split|Template:Ambox{{!}}Example 1|Template:Ambox{{!}}Example 2|Template:Ambox{{!}}Example 3|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
73f5044c8b972e18c3b7880f94b0644e4a0e6ac7
Template:Split/doc
10
131
153
2025-08-20T01:23:48Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Ambox/doc]]
286a3914c1d2770ff27394ac3d3f36a685542cb8
Template:Anchor
10
132
154
2025-08-20T01:23:48Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
--><span id="{{{1}}}"></span><!--
--></includeonly><!--
--><noinclude>{{doc}}
[[Category:Navigation templates]]</noinclude>
08ccba46722925866447768d344bf540b0b55e79
Template:Anchor/doc
10
133
155
2025-08-20T01:23:49Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
== Summary ==
This template can be used to insert an invisible anchor (reference points) into a page that can later be used by internal wiki links.
== Usage ==
To create a custom anchor, use <code><nowiki>{{Anchor|Anchor Name}}</nowiki></code> anywhere in the page.
For example, if you create the anchor <code><nowiki>{{Anchor|Example Anchor}}</nowiki></code> in the page <code><nowiki>[[Example]]</nowiki></code>, you can access it through the internal link <code><nowiki>[[Example#Example Anchor]]</nowiki></code>.
Remember that you can create a [[support:Redirect|redirect]] to this template so that you can call it more easily, such as with <code><nowiki>{{a|Anchor Name}}</nowiki></code>.
<noinclude>[[Category:Template documentation]]</noinclude>
4b0ddb50416a354db262e62617d9b45056f4d526
Template:Key/doc/Xbox
10
134
156
2025-08-20T01:23:50Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Images source: [[dev:Category:Xbox input images]]
=== Series & One ===
<code><nowiki>{{Key|Xbox|A}}</nowiki></code>
{{Key|Xbox|A}}
<code><nowiki>{{Key|Xbox|B}}</nowiki></code>
{{Key|Xbox|B}}
<code><nowiki>{{Key|Xbox|X}}</nowiki></code>
{{Key|Xbox|X}}
<code><nowiki>{{Key|Xbox|Y}}</nowiki></code>
{{Key|Xbox|y}}
<code><nowiki>{{Key|Xbox|Left Thumbstick}}</nowiki></code>
{{Key|Xbox|Left Thumbstick}}
<code><nowiki>{{Key|Xbox|Right Thumbstick}}</nowiki></code>
{{Key|Xbox|Right Thumbstick}}
<code><nowiki>{{Key|Xbox|Left Thumbstick Press}}</nowiki></code>
{{Key|Xbox|Left Thumbstick Press}}
<code><nowiki>{{Key|Xbox|Right Thumbstick Press}}</nowiki></code>
{{Key|Xbox|Right Thumbstick Press}}
<code><nowiki>{{Key|Xbox|LB}}</nowiki></code>
{{Key|Xbox|LB}}
<code><nowiki>{{Key|Xbox|RB}}</nowiki></code>
{{Key|Xbox|RB}}
<code><nowiki>{{Key|Xbox|View}}</nowiki></code>
{{Key|Xbox|View}}
<code><nowiki>{{Key|Xbox|Menu}}</nowiki></code>
{{Key|Xbox|Menu}}
<code><nowiki>{{Key|Xbox|Button}}</nowiki></code>
{{Key|Xbox|Button}}
=== Xbox Series ===
<code><nowiki>{{Key|Xbox|D-pad}}</nowiki></code>
{{Key|Xbox|D-pad}}
<code><nowiki>{{Key|Xbox|D-pad Left}}</nowiki></code>
{{Key|Xbox|D-pad Left}}
<code><nowiki>{{Key|Xbox|D-pad Right}}</nowiki></code>
{{Key|Xbox|D-pad Right}}
<code><nowiki>{{Key|Xbox|D-pad Up}}</nowiki></code>
{{Key|Xbox|D-pad Up}}
<code><nowiki>{{Key|Xbox|D-pad Down}}</nowiki></code>
{{Key|Xbox|D-pad Down}}
<code><nowiki>{{Key|Xbox|LT}}</nowiki></code>
{{Key|Xbox|LT}}
<code><nowiki>{{Key|Xbox|RT}}</nowiki></code>
{{Key|Xbox|RT}}
<code><nowiki>{{Key|Xbox|Share}}</nowiki></code>
{{Key|Xbox|Share}}
==== Diagram ====
<code><nowiki>{{Key|Xbox|Series Controller Diagram}}</nowiki></code>
{{Key|Xbox|Series Controller Diagram}}
=== Xbox One ===
<code><nowiki>{{Key|Xbox|One D-pad}}</nowiki></code>
{{Key|Xbox|D-pad}}
<code><nowiki>{{Key|Xbox|One D-pad Left}}</nowiki></code>
{{Key|Xbox|D-pad Left}}
<code><nowiki>{{Key|Xbox|One D-pad Right}}</nowiki></code>
{{Key|Xbox|D-pad Right}}
<code><nowiki>{{Key|Xbox|One D-pad Up}}</nowiki></code>
{{Key|Xbox|D-pad Up}}
<code><nowiki>{{Key|Xbox|One D-pad Down}}</nowiki></code>
{{Key|Xbox|D-pad Down}}
<code><nowiki>{{Key|Xbox|One Left Trigger}}</nowiki></code>
{{Key|Xbox|One Left Trigger}}
<code><nowiki>{{Key|Xbox|One Right Trigger}}</nowiki></code>
{{Key|Xbox|One Right Trigger}}
==== Diagram ====
<code><nowiki>{{Key|Xbox|One Controller Diagram}}</nowiki></code>
{{Key|Xbox|One Controller Diagram}}
__NOTOC__
<noinclude>[[Category:Key template documentation]]</noinclude>
adce81e2e9eafcf930052a8993d3e5625665202e
Template:Key/doc/DualSense
10
135
157
2025-08-20T01:23:50Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Images source: [[dev:Category:DualSense input images]]
=== Buttons ===
<code><nowiki>{{Key|PS|Directional}}</nowiki></code>
{{Key|PS|Directional}}
<code><nowiki>{{Key|PS|Directional Left}}</nowiki></code>
{{Key|PS|Directional Left}}
<code><nowiki>{{Key|PS|Directional Right}}</nowiki></code>
{{Key|PS|Directional Right}}
<code><nowiki>{{Key|PS|Directional Up}}</nowiki></code>
{{Key|PS|Directional Up}}
<code><nowiki>{{Key|PS|Directional Down}}</nowiki></code>
{{Key|PS|Directional Down}}
<code><nowiki>{{Key|PS|Left Stick}}</nowiki></code>
{{Key|PS|Left Stick}}
<code><nowiki>{{Key|PS|Right Stick}}</nowiki></code>
{{Key|PS|Right Stick}}
<code><nowiki>{{Key|PS|Touch Pad}}</nowiki></code>
{{Key|PS|Touch Pad}}
<code><nowiki>{{Key|PS|Circle}}</nowiki></code>
{{Key|PS|Circle}}
<code><nowiki>{{Key|PS|Cross}}</nowiki></code>
{{Key|PS|Cross}}
<code><nowiki>{{Key|PS|Square}}</nowiki></code>
{{Key|PS|Square}}
<code><nowiki>{{Key|PS|Triangle}}</nowiki></code>
{{Key|PS|Triangle}}
<code><nowiki>{{Key|PS|Create}}</nowiki></code>
{{Key|PS|Create}}
<code><nowiki>{{Key|PS|Options}}</nowiki></code>
{{Key|PS|Options}}
<code><nowiki>{{Key|PS|L1}}</nowiki></code>
{{Key|PS|L1}}
<code><nowiki>{{Key|PS|R1}}</nowiki></code>
{{Key|PS|R1}}
<code><nowiki>{{Key|PS|L2}}</nowiki></code>
{{Key|PS|L2}}
<code><nowiki>{{Key|PS|R2}}</nowiki></code>
{{Key|PS|R2}}
<code><nowiki>{{Key|PS|L3}}</nowiki></code>
{{Key|PS|L3}}
<code><nowiki>{{Key|PS|R3}}</nowiki></code>
{{Key|PS|R3}}
<code><nowiki>{{Key|PS|Mute}}</nowiki></code>
{{Key|PS|Mute}}
<code><nowiki>{{Key|PS|PS}}</nowiki></code>
{{Key|PS|PS}}
=== Diagram ===
<code><nowiki>{{Key|PS|Controller Diagram}}</nowiki></code>
{{Key|PS|Controller Diagram}}
<noinclude>[[Category:Key template documentation]]</noinclude>
84fa5123f9494d3572fef65e1aa63dd95ef476be
Template:Gad
10
136
158
2025-08-20T01:23:51Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<code>Gadget-[[MediaWiki:Gadget-{{{1}}}|{{{1}}}]]</code><noinclude>[[Category:Formatting templates]]</noinclude>
dd027468a6022472506b1fc2973d6299ec01e854
Template:From Wikipedia
10
137
159
2025-08-20T01:23:52Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = darkblue
| icon = Wikipedia.svg
| title= This code is adapted from [[wikipedia:Main Page|Wikipedia]].
| message = For the original code, see the following pages: {{#arraymap:{{{1|}}}|,|%s|[[wikipedia:%s|%s]]}}
| tiny = {{{tiny|}}}
| class = {{{class|}}}
}}</includeonly><noinclude>{{doc}}</noinclude>
0bb256ef5acc38fb0cfbdacc22e75aab89bd6e2c
Template:!-!
10
138
160
2025-08-20T01:23:52Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
|-|<noinclude>{{documentation}}</noinclude>
c634369c1e88b95ebe6a6d827cb32dc1e9c61fec
Template:!-!/doc
10
139
161
2025-08-20T01:23:56Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:((/doc]]
509bb731d447456a18489848c8a1ce38feddabcc
Template:Color
10
140
162
2025-08-20T01:23:56Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><span class="color">{{{1}}} <span class="color__splotch" style="background-color: {{{1}}};" title="{{{1}}}"></span></span>[[Category:Pages with colors]]</includeonly><noinclude>
{{doc}}
[[Category:Formatting templates]]
</noinclude>
8d576236ad82770d3c04720d4ac105edcb835874
Template:Color/doc
10
141
163
2025-08-20T01:23:57Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template creates a small color splotch with a given background color next to a plaintext color code. This is useful for previewing colors.
==Usage==
{{tlx|color|<color>}}
Where <code><color></code> is any valid [https://developer.mozilla.org/en-US/docs/Web/CSS/color_value CSS color].
==Examples==
<pre>
My favorite color is {{color|darkgreen}}
I think the current {{color|#6d8afb}} of links should be changed to a {{color|#6df4fb}}
RGB is cool too, you can do {{color|rgb(128,255,128)}}, or even transparency with {{color|rgba(128,255,128,0.5)}}.
</pre>
Produces:
My favorite color is {{color|darkgreen}}
I think the current {{color|#6d8afb}} of links should be changed to a {{color|#6df4fb}}
RGB is cool too, you can do {{color|rgb(128,255,128)}}, or even transparency with {{color|rgba(128,255,128,0.5)}}.
<noinclude>[[Category:Template documentation]]</noinclude>
cb66b177cf785e1b3f60e28e36852b253e4b3d82
Template:Example character infobox
10
142
164
2025-08-20T01:23:57Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
<!-- See https://support.wiki.gg/wiki/DRUID_infoboxes for extra documentation -->
<!-- the "kind" categorizes this type of infobox. For example, you might want to write `Character`, `Level`, or `Item`. -->
<!-- This `kind` value should be unique to this template, and no other infobox template should have the same value -->
|kind=example-1
<!-- You can almost certainly leave the separator alone, unless one of your *section names* has a comma in it -->
|sep=,
<!-- feel free to edit the 300px but mostly try to avoid changing this next line unless you are adding tabs -->
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
<!-- every infobox needs a |sections= parameter, which lists the groups of sections, in order top to bottom -->
|sections=General Info, Stats
<!-- for each section, specify the list of fields that you want to show up in that section, top to bottom -->
<!-- empty fields (not specified on the content page) will not show up -->
|General Info=Region,Element
|Stats=Attack, HP, Armor, Attack Speed
<!-- this field formats the `Attack Speed` parameter when it's specified by the content page, adding a % sign to the end of it. -->
<!-- this is an optional operation to do, only do it if you need to provide some extra formatting -->
|Attack Speed={{#if:{{{Attack Speed|}}}|{{{Attack Speed}}}%}}
}}<!--
Here is the above code without comments for easier copy-pasting:
{{#invoke:Infobox|main
|kind=example-1
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=General Info, Stats
|General Info=Region,Element
|Stats=Attack, HP, Armor, Attack Speed
|Attack Speed={{#if:{{{Attack Speed|}}}|{{{Attack Speed}}}%}}
}}
--></includeonly><noinclude>
{{documentation}}
[[Category:Infobox templates]]</noinclude>
f49d0f82d5a212306ff66b8fee112ecf88123576
Template:Example character infobox/doc
10
143
165
2025-08-20T01:23:58Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<noinclude>Are you trying to edit [[Template:Example character infobox]]? If so, you may be in the wrong place - this is the '''documentation page''', not the template itself. To edit the template, please go here: {{fullurl:Template:Example character infobox|action=edit}}
</noinclude>This is an example character infobox using the [[support:DRUID infoboxes|DRUID infoboxes]] framework. You can edit it, rename it, or delete it as desired.
== Modify this template ==
To see how DRUID works, please '''edit this page'''! It has several comments explaining the different parts of how to make an infobox.
== Copyable code for use on other content pages ==
If you want to create pages using this infobox, you can use the snippet below. Please understand, this code is for CONTENT PAGES ONLY!! It does not have anything to do with changing what the template supports.
<syntaxhighlight lang="wikitext" style="overflow: auto;">
{{Example character infobox
|title=
|image=
|Region=
|Element=
|Attack=
|HP=
|Armor=
|Attack Speed=
}}
</syntaxhighlight><noinclude>[[Category:Template documentation]]</noinclude>
cc625bd426cde7dbdfa16b8330ff21cd1ef2e942
Template:License/indie.io
10
144
166
2025-08-20T01:23:58Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = developer
| darkIcon = yes
| icon = [[File:IN COPYRIGHT.svg|50px|link=https://rightsstatements.org/page/InC/1.0/?language=en|IN COPYRIGHT]]
| text = This file is owned by [https://indie.io indie.io] and/or its licensors, and is licensed under the [https://indie.io indie.io] [https://www.indie.io/terms-of-service Terms of Use].<br/>
All trademarks and registered trademarks present in the file are proprietary to [https://indie.io indie.io] and/or its licensors.
}}</includeonly><noinclude>
This template currently looks like: {{License/indie.io}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
49823bdf8d378ff755fa7b6493afde40f6a4e19a
167
166
2025-08-20T01:23:59Z
ARTIFICER
564804
Protected "[[Template:License/indie.io]]" ([Edit=Allow only wiki.gg staff] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = developer
| darkIcon = yes
| icon = [[File:IN COPYRIGHT.svg|50px|link=https://rightsstatements.org/page/InC/1.0/?language=en|IN COPYRIGHT]]
| text = This file is owned by [https://indie.io indie.io] and/or its licensors, and is licensed under the [https://indie.io indie.io] [https://www.indie.io/terms-of-service Terms of Use].<br/>
All trademarks and registered trademarks present in the file are proprietary to [https://indie.io indie.io] and/or its licensors.
}}</includeonly><noinclude>
This template currently looks like: {{License/indie.io}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
49823bdf8d378ff755fa7b6493afde40f6a4e19a
Template:-
10
145
168
2025-08-20T01:23:59Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:Clear]]
1a2aa4a9ba7478e54a2b21cbce68887ea297ea86
Template:Clear/doc
10
146
169
2025-08-20T01:24:00Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template allows you to [https://developer.mozilla.org/en-US/docs/Web/CSS/clear clear] the left side, the right side, or both by adding <code><div style="clear:left/right/both;"></div></code>
==Usage==
{{tlx|Clear}}: Makes content wait until existing content is completed in all columns. Often used to stop text from flowing next to unrelated images. An optional <code>class</code> parameter can additionally be given for custom functionality.
To clear the left, simply put {{tlx|Clear|left}}. To clear the right, put {{tlx|Clear|right}}. To clear both sides, put {{tlx|Clear}}.
This template can also be called with {{tlx|-}} for short.
<templatedata>
{
"params": {
"1": {
"label": "Direction",
"description": "Which direction to clear",
"type": "string",
"default": "both",
"suggestedvalues": [
"left",
"right",
"both"
]
},
"class": {
"label": "Class",
"description": "A class to give to the clear",
"type": "string"
}
},
"description": "Clears the left, right, or both.",
"format": "inline"
}
</templatedata>
<noinclude>
[[Category:Template documentation]]
</noinclude>
30e700cb1ba6902a86860319bd230680193d3b04
Template:Discord
10
147
170
2025-08-20T01:24:01Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#if:{{{1|{{{id|}}}}}}|<!--
-->{{#ifeq: {{lc:{{{full|}}}<!-- -->}} | yes<!--
display the full widget:
-->|<div class="DiscordIntegrator" style="width: {{#or:{{{width|}}}|100%}}; height: {{#or:{{{height|}}}|300px}}"
data-id="{{{1|{{{id}}}}}}"
data-logged-in="{{{loggedIn}}}"
data-theme="{{{theme|}}}"
data-width="100%"
data-height="100%"><!--
-->If you see this, your JavaScript might be disabled or DiscordIntegrator plugin isn't working. If the latter, please contact a wiki administrator.</div><!--
display only the small widget:
-->|<div id="discord-compact-widget" data-id="{{{1|{{{id}}}}}}"></div><!--
-->}}<!--
case: id is not supplied
-->|<strong class="error">DiscordIntegrator error: ID of the server isn't supplied.</strong> For instructions on how to find a Discord server ID, see [https://support.discord.com/hc/articles/206346498 this Discord Help Center article]<!--
-->}}</includeonly><!--
-->[[Category:Pages with Discord embeds]]<noinclude>{{Documentation}}
[[Category:Templates]]</noinclude>
7d39c3a9d1b4eb8e95becaf418c16ec30cb9c077
Template:Discord/doc
10
148
171
2025-08-20T01:24:02Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template allows you to either use [[support:DiscordCompact|DiscordCompact]] or [[support:DiscordWidget|DiscordWidget]] to display information about a certain Discord server.
== Usage ==
In order to be able to show a Discord server widget on your wiki, first go to your Discord server and do the following:
* Open the <code>Server Settings</code>, then go to the <code>Engagement</code> section.
* Scroll down to <code>Server Widget</code>.
* Enable the widget.
* Copy the <code>Server ID</code>.
Then, do the following depending on the type of widget you want to use (compact or full).
=== Compact widget (default) ===
{{main|support:DiscordCompact{{!}}DiscordCompact}}
The compact widget is the default one.
To use it, simply add the template with the server ID either as the '''first''' parameter or as the <code>id</code> parameter:
* <code><nowiki>{{Discord|serverID}}</nowiki></code>
* <code><nowiki>{{Discord|id=serverID}}</nowiki></code>
=== Full widget ===
{{main|support:DiscordWidget{{!}}DiscordWidget}}
To use the full version of the Discord widget, you have to specify <code>full=yes</code> as one of the template parameters, with the ID either as the '''first''' parameter or as the <code>id</code> parameter:
* <code><nowiki>{{Discord|serverID|full=yes}}</nowiki></code>
* <code><nowiki>{{Discord|full=yes|id=serverID}}</nowiki></code>
You can further customize the widget with the <code>width</code>, <code>height</code> and other parameters. See the Examples section and the full documentation for DiscordWidget on the [[support:DiscordWidget|Support Wiki]].
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Discord|951501892553424917}}</nowiki></code><br/><code><nowiki>{{Discord|id=951501892553424917}}</nowiki></code> || {{Discord|951501892553424917}}
|-
| <code><nowiki>{{Discord|951501892553424917}|full=yes}</nowiki></code> || {{Discord|951501892553424917|full=yes}}
|-
| <pre><nowiki>{{Discord|full=yes
|id = 951501892553424917
|width = 300px
|height = 500px
}}</nowiki></pre> || {{Discord|full=yes|id=951501892553424917|width=300px|height=500px}}
|}
== Dependencies ==
* As stated before, both Compact and Widget require the given Discord server to have Widgets enabled in its Server Settings.
* Both Compact and Widget require the <code>discordTemplate</code> gadget:
** [[MediaWiki:Gadgets/discordTemplate]]
** [[MediaWiki:Gadgets/discordTemplate/main.js]]
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"aliases": [
"id"
],
"label": "Server ID",
"description": "The Discord server's ID.",
"example": "951501892553424917",
"type": "line",
"required": true
},
"full": {
"label": "Use full widget",
"example": "yes",
"type": "boolean",
"description": "Do you want to use the full widget?"
},
"width": {
"label": "Width (full widget only)",
"description": "A custom width for the full widget.",
"example": "300px",
"type": "line"
},
"height": {
"label": "Height (full widget only)",
"description": "A custom height for the full widget.",
"example": "500px",
"type": "line"
}
},
"description": "This template allows you to either use DiscordCompact or DiscordWidget to display information about a certain Discord server.",
"paramOrder": [
"1",
"full",
"width",
"height"
],
"format": "block"
}
</templatedata>
2b1165b9383a06a5766054d0d38b8b045cf83b25
Template:Main page box/end
10
149
172
2025-08-20T01:24:02Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly></div>
</div></includeonly><noinclude>
{{doc}}
[[Category:Main page templates]]
</noinclude>
506617faba565eb65144b21c3ead8fe5c2010b55
Template:Main page box/start
10
150
173
2025-08-20T01:24:03Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><div class="mp-box <!--
These variables are used to determine if certain layouts should hide certain boxes.
The variable is created in and passed from [[Module:Main page]], and is formatted as a pseudo bitmask to reduce variable usage
An example of this variable would be "1,1,0," which would mean display on desktop and tablet but not on mobile
-->{{#ifeq:{{#explode:{{#var:imp-variable-display-box}}|,|0}}|0|mp-hide-on-desktop}} <!--
-->{{#ifeq:{{#explode:{{#var:imp-variable-display-box}}|,|1}}|0|mp-hide-on-tablet}} <!--
-->{{#ifeq:{{#explode:{{#var:imp-variable-display-box}}|,|2}}|0|mp-hide-on-mobile}} <!--
-->{{{class|}}}" style="grid-area:{{#var:imp-variable-id}}; {{{style|}}}" id="mp-box-{{#var:imp-variable-id}}" data-box-id="{{#var:imp-variable-id}}"><!--
-->{{#if:{{{title|{{{1|}}}}}}|
<h2> {{{title|{{{1|}}}}}} </h2>
}}<div class="mp-body"></includeonly><noinclude>
{{doc}}
[[Category:Main page templates]]
</noinclude>
62eedb503b63a36fc31a301f8ea6b15f6ff9bf60
Template:Main page box/preload
10
151
174
2025-08-20T01:24:04Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = $1
}}
Content goes here, between the start and end templates.
Feel free to use wikitext, tables, templates, new lines, whatever.
{{Main page box/end}}<includeonly><no<noinclude></noinclude>include>[[Category:Main page boxes]]</no<noinclude></noinclude>include></includeonly><!-- don't edit this line --><noinclude>
[[Category:Main page templates]]
</noinclude>
9b16288e15e3c8c9ede76b4dc76e538d2253cf23
Template:Main page
10
152
175
2025-08-20T01:24:04Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#invoke:Main page|main}}
__NOTOC__
__NOEDITSECTION__
[[Category:{{SITENAME}}| ]]</includeonly><noinclude>
{{doc}}
[[Category:Main page templates]]
</noinclude>
64a0dbb502a75c44e4b3f474772d8502bdf44e40
Template:Main page box/create
10
153
176
2025-08-20T01:24:05Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{#tag: inputbox |
type = create
width = 40
default = {{{1|}}}
buttonlabel = Create this box
prefix = {{#or:{{{rootpage|}}}|{{MediaWiki:Mainpage}}}}/
placeholder = box name (no spaces)
preload = Template:Main page box/preload
summary = Created using preload
preloadparams[] = {{ucfirst:{{{1|Example}}}}}
}}<noinclude>[[Category:Main page templates]]</noinclude>
da58eca98a44a09e476c5b4a5cafde116b6cdac9
Template:Main page box
10
154
177
2025-08-20T01:24:05Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><code>Template:Main page box</code> is not intended to be used directly, please use [[Template:Main page box/start]] and [[Template:Main page box/end]].</includeonly><noinclude>
This template is used to create the boxes of the IMProved Main Page (IMP) framework. '''It should not be called directly''', instead using {{tl|Main page box/start}} and {{tl|Main page box/end}}.
<div style="text-align:center;">
Use the box below to create a page with the required templates already in place, ready for you to add your content.
{{/create}}
The box name can not contain spaces or start with a number. Those are probably the only restrictions you'll run into, but for a full list see [https://developer.mozilla.org/en-US/docs/Web/CSS/custom-ident <custom-ident> on MDN web docs].
</div>
==Parameters==
These are the parameters used by {{tl|Main page box/start}}. All parameters are optional.
{| class="wikitable"
! Name !! Data type !! Description
|-
| title || Wikitext || The title of the box. This can be empty, in which case the box will contain only the content.
|-
| class || CSS classes || A list of classes to be passed to the box, separated by spaces and without quotes. Standard options are <code>centered-content</code> to vertically center contents, and <code>has-floating-image</code> in case floating images are needed in the box (normally the flex layout disallows this).
|-
| style || CSS declarations || Inline CSS to be applied directly to the box, without quotes. A common usage is <code>text-align:center;</code> for cases where it's desired for individual boxes to have centered text.
|}
[[Category:Main page templates]]
[[Category:Template documentation]]
</noinclude>
cbbd25d1eb0105a8be55d0cc174f385fc467ffad
Template:Main page box/start/doc
10
155
178
2025-08-20T01:24:06Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
See [[Template:Main page box]] for information on how to use this.
==TemplateData==
<templatedata>
{
"params": {
"class": {
"label": "Class",
"description": "Additional classes to give to the box wrapping this box.",
"example": "centered-content",
"suggestedvalues": [
"centered-content",
"has-floating-image"
]
},
"style": {
"label": "Style",
"description": "Inline CSS to add to the box wrapping this box",
"example": "text-align:center;",
"type": "string"
},
"title": {
"aliases": [
"1"
],
"label": "Title",
"description": "The title of this box.",
"example": "Welcome to the wiki!",
"type": "content",
"suggested": true
}
},
"description": "Creates a box for use on the main page.",
"paramOrder": [
"title",
"class",
"style"
],
"format": "block"
}
</templatedata>
<noinclude>[[Category:Template documentation]]</noinclude>
860e1be8fbf205ab2b3214cb91860a77fd3ef52b
Template:Main page box/end/doc
10
156
179
2025-08-20T01:24:07Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
See [[Template:Main page box]] for information on how to use this.
<noinclude>[[Category:Template documentation]]</noinclude>
e73182bed655118b10da971b634dc9c3bf3e3d39
Template:Main page/doc
10
157
180
2025-08-20T01:24:07Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template is used to create an IMP Main Page. It uses [[Module:Main page]] to arrange a series of [[Template:Main page box]]es in a [https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_grid_layout CSS grid].
==Simple explanation==
The layout is made using keywords arranged in a grid. This grid has 3 columns on desktop-width screens, 2 columns on tablet, and 1 on mobile. Each can have as many rows as you want. Each keyword represents the same section and can span multiple rows and/or columns, but ''must'' form a contiguous rectangle of any dimension (1x1, 1x2, 2x2, 2x3, etc.).
For example, the following input to desktop:
<pre style="display:table;">
welcome welcome welcome
about links links
about contribute contribute
</pre>
would produce a grid resembling the following:
{| class="wikitable"
| style="background-color:rgba(0,255,0,0.15)" | welcome
| style="background-color:rgba(0,255,0,0.15)" | welcome
| style="background-color:rgba(0,255,0,0.15)" | welcome
|-
| style="background-color:rgba(255,0,255, 0.15)" | about
| style="background-color:rgba(0,0,255, 0.15)" | links
| style="background-color:rgba(0,0,255, 0.15)" | links
|-
| style="background-color:rgba(255,0,255, 0.15)" | about
| style="background-color:rgba(255,255,0, 0.15)" | contribute
| style="background-color:rgba(255,255,0, 0.15)" | contribute
|}
Where <code>welcome</code> is the contents of [[{{MediaWiki:Mainpage}}/welcome]], <code>about</code> is the contents of [[{{MediaWiki:Mainpage}}/about]], and so on. See [[Template:Main page box]] for more information about creating your own boxes.
If you enter a keyword that does not have a corresponding box already, you'll be prompted to create one when saving or previewing the page.
If you leave a keyword out of a certain layout, it will not be displayed on that layout. A warning will be given at the top of the edit preview in case this was an accident, but can be safely ignored if intentional.
For additional hints and information, see the comments that came on your main page or ask a wiki.gg staff member for help.
==Technical explanation==
For the CSS savvy, this section explains how it works a bit under the hood.
The input to desktop, tablet, and mobile create [https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties CSS variables] which are then used as the value of [https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-areas grid-template-areas] in media queries for screen widths >=1350px, >=990px, and <990px. The boxes are given an id based on their subpage name, which is then used by the module to find the template, as well as by the box templates to assign them a CSS id of <code>mp-box-<keyword></code>. Since these keywords are used directly in the grid layout, they must follow the rules of [https://developer.mozilla.org/en-US/docs/Web/CSS/custom-ident <custom-ident>] naming.
==Dependencies==
For this template to work properly, you need the following:
* [[Module:Main page]]
* All templates in [[:Category:Main page templates]].
* All CSS within the "Main page layout" section found in [[MediaWiki:Common.css]].
The <code>[[MediaWiki:Gadgets/mpEditLinks|mpEditLinks]]</code> gadget is also highly recommended. Its code can be found at [[MediaWiki:Gadgets/mpEditLinks/main.css]] and [[MediaWiki:Gadgets/mpEditLinks/main.js]].
==TemplateData==
<templatedata>
{
"params": {
"desktop": {
"label": "Desktop",
"description": "The layout for wide screens",
"required": true,
"type": "string"
},
"tablet": {
"label": "Tablet",
"description": "The layout for mid-width screens",
"required": true,
"type": "string"
},
"mobile": {
"label": "Mobile",
"description": "The layout for narrow screens",
"required": true,
"type": "string"
}
},
"description": "Creates an IMP Main Page.",
"format": "block"
}
</templatedata>
<noinclude>[[Category:Template documentation]]</noinclude>
c5052ca4c6f9f0e1e2c0a81cea00e372d4bacdca
Template:Ct
10
158
181
2025-08-20T01:24:08Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<code><nowiki>[</nowiki>[[Special:CargoTables/{{{1}}}|{{{1}}}]]<nowiki>]</nowiki>{{#if:{{{2|}}}|.{{{2}}}}}</code><noinclude>
[[Category:Formatting templates]]</noinclude>
d868545d4d3eeb1545e963d063199a68abba7836
Template:Main page box/missing
10
159
182
2025-08-20T01:24:08Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{Main page box/start
| title = {{{1}}}
| style = text-align:center;
| class = missing
}}
The {{{1}}} box does not exist. Check your spelling or create it here:<br/>
{{Main page box/create|{{{1|}}}|rootpage = {{{rootpage|}}}}}<br/>
See [[Template:Main page box]] for more information.
{{Main page box/end}}<noinclude>[[Category:Main page templates]]</noinclude>
5cff88dacf33c912d4aa04c1541e684a5f3e79bb
Template:Iter
10
160
183
2025-08-20T01:24:09Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{#vardefine:varname|ITER_INDEX_{{#if:{{{1|}}}|{{{1}}}|default}}<!-- end vardefine -->}}<!--
main logic
-->{{#vardefineecho:{{#var:varname}}|
{{#expr:
{{#ifeq:{{lc:{{{reset|}}}<!-- end lc -->}}
|yes
|0
|{{#var:{{#var:varname}}|0}}
<!-- end ifeq -->}} + {{#if:{{{get|}}}|0|1}}
<!-- end expr -->}}
<!-- end vde -->}}</includeonly><noinclude>{{documentation}}
[[Category:Templates]]</noinclude>
c37a3625d58a115a140f129da248ec1c9f6cb55e
Template:Iter/doc
10
161
184
2025-08-20T01:24:09Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template helps you create indexed columns in tables (particularly [[support:Cargo|Cargo]] queries) and to retrieve iterator values when using the parser function <code><nowiki>{{#arraymaptemplate</nowiki></code> (bundled with Extension:ParserPower on wiki.gg).
== Simple counting ==
<pre>
* {{iter|}}
* {{iter|}}
* {{iter|}}
* {{iter|}}
</pre>
* {{iter|}}
* {{iter|}}
* {{iter|}}
* {{iter|}}
== Reset the counter ==
<pre>
* {{iter|reset=yes}}
* {{iter|}}
* {{iter|reset=yes}}
* {{iter|}}
</pre>
* {{iter|reset=yes}}
* {{iter|}}
* {{iter|reset=yes}}
* {{iter|}}
== Multiple counters ==
<pre>
* {{iter|key1}}
* {{iter|key2}}
* {{iter|key2}}
* {{iter|key1}}
</pre>
* {{iter|key1}}
* {{iter|key2}}
* {{iter|key2}}
* {{iter|key1}}
== Get value without incrementing ==
<pre>
* {{iter|reset=yes}}
* {{iter|}}
* {{iter|}}
* {{iter|get=yes}}
</pre>
* {{iter|reset=yes}}
* {{iter|}}
* {{iter|}}
* {{iter|get=yes}}
<noinclude>
[[Category:Template documentation]]
</noinclude>
20b5a53a6457493d2a2a9774b803511678a65760
Template:License/permission
10
162
185
2025-08-20T01:24:10Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = permission
| icon = [[File:IN COPYRIGHT.svg|50px|link=|IN COPYRIGHT WITH PERMISSION]]
| text = This file is copyrighted. The copyright holder has given permission for its use on wiki.gg.
}}</includeonly><noinclude>
This template currently looks like: {{License/permission}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
854af75c8477c36c50cb5d103ad8a933892fc322
186
185
2025-08-20T01:24:11Z
ARTIFICER
564804
Protected "[[Template:License/permission]]" ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{License/template
| source = {{{source|}}}
| type = permission
| icon = [[File:IN COPYRIGHT.svg|50px|link=|IN COPYRIGHT WITH PERMISSION]]
| text = This file is copyrighted. The copyright holder has given permission for its use on wiki.gg.
}}</includeonly><noinclude>
This template currently looks like: {{License/permission}}
See {{tl|License}} for full license documentation
[[Category:License templates]]</noinclude>
854af75c8477c36c50cb5d103ad8a933892fc322
Template:Flag
10
163
187
2025-08-20T01:24:11Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><!--
--><span class="country-flag" title="{{{2|}}}">{{#if: {{{1|}}} | [[File:Flag {{{1|}}}.svg|x20px|link=]] | }}</span><!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Formatting templates]]</noinclude>
9802f61bee0e36120c835608ccee85e72384341b
Template:Flag/doc
10
164
188
2025-08-20T01:24:12Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This formatting template allows you to display country flags inline.
Available country flags can be seen in [[dev:Category:Country_flags|our Commons Wiki]].
== Usage ==
The template can be used with the following formatting: <code><nowiki>{{flag|code|Legend}}</nowiki></code>, where:
* <code>code</code> is the [[wikipedia:ISO 3166-1 alpha-2|ISO 3166-1 alpha-2]] code for the country flag.
* <code>Legend</code> is the legend displayed on hover (optional).
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{flag|ca|Canada}}</nowiki></code> || {{flag|ca|Canada}}
|}
<noinclude>[[Category:Template documentation]]</noinclude>
1fb455be1ffbed259dd27df18dd447e605746ed4
Template:Disambig
10
165
189
2025-08-20T01:24:12Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#redirect [[Template:Disambiguation]]
f220bcb889e0ce686a839d64ec6c4359b0e8bfb7
Template:TOC limit
10
166
190
2025-08-20T01:24:13Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><div class="toclimit-{{{1|{{{limit|3}}}}}}">__TOC__</div></includeonly><noinclude>
{{documentation}}
[[Category:Table of contents templates]]
</noinclude>
9187098528659316936c0da0589a7745f10e38e3
Template:TOC limit/doc
10
167
191
2025-08-20T01:24:14Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This template inserts a Table of Contents that omits subheadings beyond a certain depth. The table obeys the same layout rules as the <nowiki>__TOC__</nowiki> [[mw:Help:Magic_words|magic word]]. Omitted sections still have section edit links in the article body. The main use for this template is situations where you want section edit links for ease of editing but don't want a full table of contents. '''Before using this template, consider whether and why it would be helpful to readers and other editors.'''
== Usage ==
{{tlx|TOC limit}} or {{tlx|TOC limit|3}}
The template defaults to including second- and third-level headings, e.g. those numbered "1" and "1.1" in the TOC. (Note: {{tlx|TOC limit|1}} does nothing: the first-level heading on a page is, by default, the page title.)
You can specify a different limit by adding a header level:
{{tlx|TOC limit|4}}
4 allows for fourth-level headings, e.g. "1.1.1", but omits any subheadings below that from the TOC.
The template works by hiding the lower levels with CSS. See [[Mediawiki:Common.css]].
== TOC levels versus wikitext header levels ==
The heading levels in the TOC normally correspond to the header levels in the wikitext, so a <code>== Level-2 header ==</code> will normally generate the first-level ("1") TOC headings, a <code>=== Level-3 header ===</code> will normally generate the second-level ("1.1") TOC headings, and so on. This correspondence does ''not'' hold if the page contains <code>= Level-1 headers =</code> or skips header levels. For example, wikitext like this:
<pre>
== Level-2 heading (A) ==
=== Level-3 heading (B) ===
== Level-2 heading (C) ==
====== Level-6 heading (D) ======
= Level-1 heading (E) =
== Level-2 heading (F) ==
=== Level-3 heading (G) ===
</pre>
will generate a TOC like this:
{| class="toc"
|<div style="text-align:center"><b>Contents</b></div>
<ul>
<li class="toclevel-1 tocsection-1"><span class="tocnumber">1</span> <span class="toctext">Level-2 heading (A)</span><ul>
<li class="toclevel-2 tocsection-2"><span class="tocnumber">1.1</span> <span class="toctext">Level-3 heading (B)</span></li>
</ul></li>
<li class="toclevel-1 tocsection-1"><span class="tocnumber">2</span> <span class="toctext">Level-2 heading (C)</span><ul>
<li class="toclevel-2 tocsection-2"><span class="tocnumber">2.1</span> <span class="toctext">Level-6 heading (D)</span></li>
</ul></li>
<li class="toclevel-1 tocsection-1"><span class="tocnumber">3</span> <span class="toctext">Level-1 heading (E)</span><ul>
<li class="toclevel-2 tocsection-2"><span class="tocnumber">3.1</span> <span class="toctext">Level-2 heading (F)</span><ul>
<li class="toclevel-3 tocsection-3"><span class="tocnumber">3.1.1</span> <span class="toctext">Level-3 heading (G)</span></li>
</ul></li>
</ul></li>
</ul>
|}
Using <code><nowiki>{{TOC limit}}</nowiki></code> on this page ''would not'' hide header D, because even though it is a level-6 heading it is shown at the second level in the TOC. And it ''would'' hide header G even though it is a level-3 heading just like header B, because header G is shown at the third level in the TOC while header B is shown at the second level.
== Conflicts ==
This template does not interact well with the {{tl|TOC right}} template. To achieve the correct effect, use those with a limit parameter. For example, {{tlx|TOC right|2=limit=2}} has the effect that {{tlx|TOC right}} and {{tlx|TOC limit|2}} would have - if they worked together.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"aliases": [
"limit"
],
"label": "Limit",
"description": "Maximum header depth to be included in table of contents",
"default": "3",
"suggested": true,
"type": "number"
}
},
"description": "Inserts a Table of Contents that omits subheadings beyond a certain depth."
}
</templatedata>
<noinclude>[[Category:Template documentation]]</noinclude>
8582cad25d72e508a04a81c36ef5ecb663a32bc7
Template:TOC right
10
168
192
2025-08-20T01:24:14Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly><div class="tocright {{#if:{{{limit|}}}|toclimit-{{{limit}}}}}">__TOC__</div></includeonly><noinclude>
{{documentation}}
[[Category:Table of contents templates]]
</noinclude>
8b94caa5343acd906cad9e74465f0ea5ce4e9549
Template:TOC right/doc
10
169
193
2025-08-20T01:24:15Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{tl|TOC right}} forces the auto-generated Table of Contents for an article to appear floated to the right side of the page in order to improve article layout.
==Usage==
Insert <code><nowiki>{{TOC right}}</nowiki></code> at the point in the article where you want the top of the Table of Contents box to appear. This should usually be after the text of the lead section, and just before the first section heading. Use with {{tl|clear}} to prevent collision with text. Avoid placing the TOC in a visually poor location. Crossing a section division is probably a poor idea.
;limit
: Limits the depth of subheadings shown. For instance using <code>limit=4</code> will hide the fourth level and deeper subheadings in the hierarchy. And <code>limit=2</code> will hide all subheadings leaving only the main headings. This works by hiding the lower levels with CSS. See {{tl|TOC limit}} for more information on this.
Do not place this template so that the TOC aligns with a large image or infobox; this breaks the layout on narrow screens (even users with screens as wide as 1024px wide can have problems). Also, a TOC that crosses a section division is probably a poor idea, if that can be avoided.
Unless the section in which the {{tl|TOC right}} is placed is long enough, the result may well be undesirable.
It should only be used in cases where the TOC gets in the way of other content or is detrimental to the layout of the page; it should ''not'' simply be used for aesthetics since it tampers with the standard appearance of articles.
==TemplateData==
<templatedata>
{
"params": {
"limit": {
"label": "Limit",
"description": "Limits the depth of subheadings shown. For instance using limit=4 will hide the fourth level and deeper subheadings in the hierarchy. And limit=2 will hide all subheadings leaving only the main headings. This works by hiding the lower levels with CSS",
"type": "number"
}
},
"description": "{{TOC right}} forces the auto-generated \"Table of Contents\" for an article to appear floated to the right side of the page (as seen right), in order to improve article layout.",
"paramOrder": [
"limit"
],
"format": "inline"
}
</templatedata>
<noinclude>[[Category:Template documentation]]</noinclude>
88415e28677a029fbca8963e109305c2d2d79643
Template:Toc limit
10
170
194
2025-08-20T01:24:16Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:TOC limit]]
cfa656c80245fbc1966e109758445db069c69934
Template:Toclimit
10
171
195
2025-08-20T01:24:16Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:TOC limit]]
cfa656c80245fbc1966e109758445db069c69934
Template:Toc right
10
172
196
2025-08-20T01:24:17Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:TOC right]]
fc00258b0a19738ebc9c13dbcc88881f9d5bff3e
Template:Tocright
10
173
197
2025-08-20T01:24:18Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
#REDIRECT [[Template:TOC right]]
fc00258b0a19738ebc9c13dbcc88881f9d5bff3e
Category:Documentation templates
14
174
198
2025-08-20T01:24:19Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Templates
14
175
199
2025-08-20T01:24:20Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:{{SITENAME}}]]
dd8aaa34cf600c1567d240a3f4bc615164a11592
Category:Bleak Faith: Forsaken Wiki
14
176
200
2025-08-20T01:24:20Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This is the top-level category. It contains meta categories and pages about the wiki.
8935f2b3e97edfeadd7bb206f1e17c03099ec24a
Category:Notice templates
14
177
201
2025-08-20T01:24:21Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Formatting templates
14
178
202
2025-08-20T01:24:21Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:License templates
14
179
203
2025-08-20T01:24:22Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Pages using DynamicPageList3 parser function
14
180
204
2025-08-20T01:24:22Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
d17f98d5d77b5951b7a80755914239533ad6aba6
Category:Candidates for deletion
14
181
205
2025-08-20T01:24:23Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Hidden categories
14
182
206
2025-08-20T01:24:24Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
These categories are hidden on article pages.
[[Category:Wiki maintenance]]
e4d17499a8377d3f2b4b4a618a671e53111f43ca
Category:Images
14
183
207
2025-08-20T01:24:24Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Media]]
b141d2b9971d6efe9f59bd03449781e71411c631
Category:Infobox templates
14
184
208
2025-08-20T01:24:25Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Logos
14
185
209
2025-08-20T01:24:25Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Images]]
8820b63e35aedd9d2666fe40b965d4e91ce0a106
Category:Media
14
186
210
2025-08-20T01:24:26Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:{{SITENAME}}]]
dd8aaa34cf600c1567d240a3f4bc615164a11592
Category:Pages containing omitted template arguments
14
187
211
2025-08-20T01:24:26Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages using TabberTransclude parser tag
14
188
212
2025-08-20T01:24:27Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
d17f98d5d77b5951b7a80755914239533ad6aba6
Category:Pages using Tabber parser tag
14
189
213
2025-08-20T01:24:28Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
d17f98d5d77b5951b7a80755914239533ad6aba6
Category:Pages using duplicate arguments in template calls
14
190
214
2025-08-20T01:24:28Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages where expansion depth is exceeded
14
191
215
2025-08-20T01:24:29Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages where template include size is exceeded
14
192
216
2025-08-20T01:24:29Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages where the unstrip depth limit is exceeded
14
193
217
2025-08-20T01:24:30Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages where the unstrip size limit is exceeded
14
194
218
2025-08-20T01:24:30Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with broken file links
14
195
219
2025-08-20T01:24:31Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Wiki maintenance]]
197b5fc8ebad5537759adacc0079b4b2662cb4c4
Category:Pages with ignored display titles
14
196
220
2025-08-20T01:24:31Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with math errors
14
197
221
2025-08-20T01:24:32Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with non-numeric formatnum arguments
14
198
222
2025-08-20T01:24:32Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with reference errors
14
199
223
2025-08-20T01:24:33Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with script errors
14
200
224
2025-08-20T01:24:34Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with syntax highlighting errors
14
201
225
2025-08-20T01:24:34Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with template loops
14
202
226
2025-08-20T01:24:35Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with too many expensive parser function calls
14
203
227
2025-08-20T01:24:35Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Promotional images
14
204
228
2025-08-20T01:24:36Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
Official images used for purposes of promoting the game, that may not actually represent gameplay.
[[Category:Images]]
80b893c439747ce681cf18cc579c3bc4c65cd502
Category:Stubs
14
205
229
2025-08-20T01:24:36Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Template documentation
14
206
230
2025-08-20T01:24:37Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
[[Category:Wiki maintenance]]
c1800be0da4588b3b652fa5324aade2c496fb3c5
Category:Templates with no documentation
14
207
231
2025-08-20T01:24:37Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Templates]]
[[Category:Wiki maintenance]]
b1ff76c0593194e53e6bf42f37ca337a5493c57e
Category:Wiki maintenance
14
208
232
2025-08-20T01:24:38Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
The sub-categories of this category contain pages that have been identified as needing attention for one or more of the following reasons:
* Changes have been suggested that should be discussed first or are under discussion.
* The page has flaws that need addressing by an editor with the knowledge or skills to help.
* The action the page needs requires special rights.
''See also:''
* [[Special:BrokenRedirects|Broken redirects]]
* [[Special:DoubleRedirects|Double redirects]]
* [[Special:UncategorizedCategories|Uncategorized categories]]
* [[Special:UncategorizedFiles|Uncategorized files]]
* [[Special:UncategorizedPages|Uncategorized pages]]
* [[Special:UncategorizedTemplates|Uncategorized templates]]
* [[Special:WantedCategories|Wanted categories]]
* [[Special:WantedFiles|Wanted files]]
* [[Special:WantedPages|Wanted pages]]
* [[Special:WantedTemplates|Wanted templates]]
* [[Special:TrackingCategories|Other special tracking categories]]
[[Category:{{SITENAME}}]]
4b90dc0dbd8c91e131e4ffcf22360b1c837b9717
Category:Wiki skin images
14
209
233
2025-08-20T01:24:38Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Images]]
8820b63e35aedd9d2666fe40b965d4e91ce0a106
Category:Pages using DynamicPageList3 dplvar parser function
14
210
234
2025-08-20T01:24:39Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
d17f98d5d77b5951b7a80755914239533ad6aba6
Category:Pages including data maps failing validation
14
211
235
2025-08-20T01:24:40Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
__HIDDENCAT__
[[Category:Wiki maintenance]]
57e36e9878c3eb806aa6ee6f748a5c5e0cdd5a97
Category:Pages including data maps
14
212
236
2025-08-20T01:24:40Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
d17f98d5d77b5951b7a80755914239533ad6aba6
Category:Maps failing data validation
14
213
237
2025-08-20T01:24:41Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
__HIDDENCAT__
[[Category:Wiki maintenance]]
57e36e9878c3eb806aa6ee6f748a5c5e0cdd5a97
Category:Legal notices
14
214
238
2025-08-20T01:24:41Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:{{SITENAME}}]]
dd8aaa34cf600c1567d240a3f4bc615164a11592
Category:Pages setting LuaCache keys
14
215
239
2025-08-20T01:24:42Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
__HIDDENCAT__
[[Category:Wiki maintenance]]
57e36e9878c3eb806aa6ee6f748a5c5e0cdd5a97
Category:Hatnote templates
14
216
240
2025-08-20T01:24:42Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Key template documentation
14
217
241
2025-08-20T01:24:43Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Template documentation]]
e65ecf60878d4707b3b4c1e3962615e2d5f3b2ab
Category:Navigation templates
14
218
242
2025-08-20T01:24:44Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Pages with failing Cargo queries
14
219
243
2025-08-20T01:24:44Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with math render errors
14
220
244
2025-08-20T01:24:45Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
786037995b8f7e89762a8ea13b84ade091453c00
Category:Pages with DRUID infoboxes
14
221
245
2025-08-20T01:24:46Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a DRUID infobox. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
17ed4520e5c453209616df3c9b2306fce8ceb12f
Category:Pages with navboxes
14
222
246
2025-08-20T01:24:46Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a {{tl|navbox}}. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
3e48f396fafee5d8aecf6cd0dcb554c769f485a9
Category:Pages with amboxes
14
223
247
2025-08-20T01:24:47Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with an {{tl|ambox}}. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
de382f794395f344d0147dbb96b9542d6f38f624
Category:Pages with hatnotes
14
224
248
2025-08-20T01:24:47Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a {{tl|hatnote}}. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
4ac7721cfcffb2f181820164d95f3af8d86c4fd7
Category:Pages with spoilers
14
225
249
2025-08-20T01:24:48Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a {{tl|spoiler}}. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
5822aa87e8a8897673ff589d00d2f0d622aa3be5
Category:Pages with quotes
14
226
250
2025-08-20T01:24:49Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a {{tl|quote}}. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
2f764cddd1fb264f48b896ffd6e892df3c391e90
Category:Pages with colors
14
227
251
2025-08-20T01:24:49Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a {{tl|color}}. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
bcca0312385263c30522c744df6a8c8856c68fab
Category:Main page templates
14
228
252
2025-08-20T01:24:50Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Main page boxes
14
229
253
2025-08-20T01:24:51Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Main page templates]]
ce086f8cfa39aeb8137ffe34e5d41aa38300cf4e
Category:Pages using the RSS extension
14
230
254
2025-08-20T01:24:51Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Wiki maintenance]]
d17f98d5d77b5951b7a80755914239533ad6aba6
Category:Pages with Discord embeds
14
231
255
2025-08-20T01:24:52Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
This category contains every page with a {{tl|Discord}} embed. It can be used for maintenance but primarily exists to enable the use of gadgets for targeted CSS and JS.
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
[[Category:Categories for loading gadgets]]
11ff5616854d8913d2c371ae3c2c610278651846
Category:Categories for loading gadgets
14
232
256
2025-08-20T01:24:52Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Wiki maintenance]]
197b5fc8ebad5537759adacc0079b4b2662cb4c4
Category:Table of contents templates
14
233
257
2025-08-20T01:24:53Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
MediaWiki:Vector.css
8
234
258
2025-08-20T01:24:54Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* All CSS here will be loaded for users of the Vector skin */
/*
This is the wiki.gg default loadout,
please do not modify it inline. To add your own skin customizations,
scroll down to the end of the default loadout (or search for "[END]" to jump there).
If you modify the sheet above that point, your changes may be overwritten in updates without warning!!!
If you want to maintain your own CSS for annual MediaWiki updates & be responsible for ALL bugfixes YOURSELF, change UPDATE in the following line to say NOUPDATE:
DLW: UPDATE
DLW VERSION: 2.2.1
IMPORTANT: if you are updating your wiki from a version before May 22, 2025,
you need to copy [[MediaWiki:Gadgets/vectorScripts]] and [[MediaWiki:Gadgets/vectorScripts/main.js]] as well or your navigation tabs will break.
*/
/*********************************************************
* Backwards compatibility with deprecated variable names *
**********************************************************/
:root {
--wiki-heading-color: var(--wiki-content-heading-color);
--wiki-heading-font-family: var(--wiki-content-heading-font-family);
--wiki-firstheading-font-family: var(--wiki-content-firstheading-font-family);
}
/****************************************
* End backwards compatibility variables *
*****************************************/
/************************************
* Body, head, and general framework *
*************************************/
:root{
--wiki-logo-box-width: calc(var(--wiki-sidebar-width, 10em) * (1 - var(--wiki-is-top-logo, 0)) + min( var(--wiki-logo-file-width, 160) / var(--wiki-logo-file-height, 160) * var(--wiki-logo-height, 160px), 100vw - var(--wiki-left-spacing, 0.5em) - var(--wiki-right-spacing, 0px) - 18px, var(--wiki-page-content-max-width, 9999px) ) * var(--wiki-is-top-logo, 0)); /* 18px: the scrollbar */
--wiki-logo-box-height: calc(var(--wiki-logo-file-height, 160) / var(--wiki-logo-file-width, 160) * var(--wiki-logo-box-width));
}
html, body {
height: auto;
min-height: 100%;
}
/* site background */
html {
background-color: var(--wiki-body-background-color);
background-image: var(--wiki-body-background-image);
/* the following have fallbacks for backwards compatibility with older versions of the loadout */
background-position: var(--wiki-body-background-position, top center);
background-size: var(--wiki-body-background-size, cover);
background-repeat: var(--wiki-body-background-repeat, no-repeat);
background-attachment: var(--wiki-body-background-attachment, fixed);
}
body {
background: none;
font-family: var(--wiki-body-font-family);
accent-color: var(--wiki-accent-color);
box-sizing: border-box;
padding-top: calc(var(--wikigg-header-height) + var(--wiki-top-spacing, 0px));
padding-bottom: var(--wiki-bottom-spacing, 0px);
padding-left: var(--wiki-left-spacing, 0px);
padding-right: var(--wiki-right-spacing, 0px);
box-sizing: border-box;
}
.skinpref-limited-width body, body.skinpref-limited-width {
--wiki-page-content-max-width: var(--wiki-content-reduced-max-width, 1300px);
}
/* clear fix */
body::after {
content: "";
display: table;
clear: both;
}
#mw-page-base,
#mw-head-base {
background: none;
--height: calc(var(--wiki-navigation-height, 3em) + var(--wiki-content-border-width, 1px) * var(--wiki-is-navigation-inside-content, 0) + var(--wiki-is-top-logo, 0) * (var(--wiki-logo-box-height, 160px) + var(--wiki-logo-margin, 15px))); /* if not is-top-logo, height of navigation, else height of navigation + logo-height + logo-margin */
height: var(--height);
}
#mw-page-base {
max-width: var(--wiki-page-content-max-width, 9999px);
margin: auto;
}
#mw-head-base {
width: calc(min(100%, var(--wiki-page-content-max-width, 9999px)) - var(--wiki-sidebar-width, 10em) - var(--wiki-gap-between-sidebar-and-content, 0.5em));
margin-top: calc(-1 * var(--height));
margin-left: calc(max(0px, 100% - var(--wiki-page-content-max-width, 9999px)) / 2 + var(--wiki-sidebar-width, 10em) + var(--wiki-gap-between-sidebar-and-content, 0.5em));
}
/* let ul default to text that respects color */
ul {
list-style-image: none;
}
/************************
* End general framework *
*************************/
/**************
* Vector tabs *
***************/
/* prevent margin collapse */
.content-wrapper::before {
content: " ";
display: table;
}
.content-wrapper{
--navigation-border-bottom-width: calc(var(--wiki-navigation-border-bottom-width, calc(var(--wiki-is-navigation-inside-content, 0) * var(--wiki-navigation-selected-border-width, 1px) + (1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-width, 1px))));
}
/****** navbar (#mw-head) ******/
.vector-menu-tabs .mw-list-item,
#p-cactions, #p-variants {
float: unset;
line-height: 1.5; /* fallback */
line-height: round(nearest, calc(var(--wiki-navigation-font-size,0.8125em)*1.5), 1px);
box-sizing: border-box;
white-space: nowrap;
}
#mw-head {
--icon-star-filled: url("data:image/svg+xml,%3C%3Fxml version='1.0'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' id='Outlined'%3E%3Cg style='fill:%23000000;fill-opacity:1' id='Fill'%3E%3Cpath style='fill:%23000000;fill-opacity:1' id='path1380' d='M 28.61,11.67 H 20 L 17.34,3.47 C 16.920093,2.1973942 15.119907,2.1973942 14.7,3.47 L 12,11.67 H 3.39 c -1.3409796,0.0031 -1.900508,1.71581 -0.82,2.51 l 7,5.07 -2.68,8.21 C 6.5980433,28.35747 7.2662365,29.278767 8.21,29.28 8.4953889,29.267666 8.7705436,29.170143 9,29 l 7,-5.07 7,5.07 c 0.236205,0.170386 0.518805,0.264586 0.81,0.27 0.943763,-0.0012 1.611957,-0.92253 1.32,-1.82 l -2.66,-8.21 7,-5.07 c 1.075277,-0.810084 0.486081,-2.522863 -0.86,-2.5 z' /%3E%3C/g%3E%3C/svg%3E");
--icon-star-empty: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='M20 7h-7L10 .5 7 7H0l5.46 5.47-1.64 7 6.18-3.7 6.18 3.73-1.63-7zm-10 6.9-3.76 2.27 1-4.28L3.5 8.5h4.61L10 4.6l1.9 3.9h4.6l-3.73 3.4 1 4.28z'/%3E%3C/svg%3E%0A");
/* icon below is from https://tabler-icons.io/ */
--icon-chevron-down: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' class='icon icon-tabler icon-tabler-chevron-down' width='24' height='24' viewBox='0 0 24 24' stroke-width='2' stroke='currentColor' fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'%3E%3C/path%3E%3Cpath d='M6 9l6 6l6 -6'%3E%3C/path%3E%3C/svg%3E");
margin-left: calc(var(--wiki-sidebar-width, 10em) + var(--wiki-gap-between-sidebar-and-content, 0.5em));
width: auto;
height: var(--wiki-navigation-height);
margin-top: calc(-1 * (var(--wiki-navigation-height) + var(--wiki-content-border-width, 1px) * var(--wiki-is-navigation-inside-content, 0)));
position: relative;
display: flex;
align-items: stretch;
z-index: 4; /* above #mw-panel and .mw-indicators */
background: var(--wiki-navigation-box-background, none);
border: calc(var(--wiki-content-border-width, 1px) * var(--wiki-is-navigation-inside-content, 0)) var(--wiki-content-border-style, solid) var(--wiki-content-border-color);
border-bottom-width: 0;
border-radius: var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) 0 0;
border-image: var(--wiki-navigation-box-border-image, none);
backdrop-filter: var(--wiki-navigation-box-backdrop-filter, none);
}
/* top border of the content */
#mw-head::before {
content: "";
display: block;
box-sizing: border-box;
position: absolute;
top: calc(100% - min(var(--wiki-navigation-left-spacing, 0px) * 999, var(--navigation-border-bottom-width)) + var(--navigation-border-bottom-width));
left: 0;
width: calc(max(var(--wiki-navigation-left-spacing, 0px), var(--navigation-border-bottom-width)));
height: calc(max(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0)), var(--navigation-border-bottom-width)));
border: 0 var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid)) var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
border-left-width: var(--navigation-border-bottom-width);
border-top-width: var(--navigation-border-bottom-width);
border-top-left-radius: calc(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0)));
}
#left-navigation,
#right-navigation {
float: none;
margin: 0;
display: flex;
align-items: flex-end;
margin-bottom: calc(-1 * var(--navigation-border-bottom-width));
}
#left-navigation {
flex: 0 0 auto;
justify-content: flex-start;
}
#right-navigation {
flex: 1 1 auto;
justify-content: flex-end;
}
#left-navigation::before,
#left-navigation::after,
#right-navigation::before,
#right-navigation::after {
content: "";
display: block;
height: 0;
border-bottom: var(--navigation-border-bottom-width) var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid)) var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
flex: 0 0 auto;
}
#left-navigation::before {
box-sizing: border-box;
width: var(--wiki-navigation-left-spacing, 0px);
border-bottom-width: 0;
}
#left-navigation::after {
width: var(--wiki-navigation-gap-between-left-and-right);
}
#right-navigation::before {
flex: 1 1 auto;
width: auto;
}
#right-navigation::after {
width: var(--wiki-navigation-right-spacing);
display: none; /* only for desktop */
}
/*** tabs ***/
/* reset */
.vector-menu,
.vector-menu *,
.vector-menu-tabs-legacy li {
background: none;
}
.vector-menu input {
border: 0;
}
/* tabs list */
.vector-menu-tabs {
height: unset;
padding: unset;
}
.vector-menu-tabs .vector-menu-content {
height: 100%;
}
.vector-menu-tabs-legacy ul{
float: none;
}
.vector-menu-tabs .vector-menu-content-list {
display: flex;
align-items: flex-end;
}
/* tab */
.vector-menu-tabs .mw-list-item,
.vector-menu-dropdown {
/* outer box of normal tabs: border-bottom */
border-bottom: var(--navigation-border-bottom-width) var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid)) var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
position: relative;
margin-right: max(0px, var(--wiki-navigation-tab-spacing)); /* make space for gap */
height: auto;
padding-bottom: var(--wiki-navigation-bottom-spacing, 0px);
cursor: auto;
}
.vector-menu-dropdown .vector-menu-checkbox{
height: calc(100% - var(--wiki-navigation-bottom-spacing, 0px));
}
.vector-menu-tabs .mw-list-item::after,
.vector-menu-dropdown::after {
/* gap */
content: "";
display: block;
width: max(0px, var(--wiki-navigation-tab-spacing));
height: 0;
border-bottom: var(--navigation-border-bottom-width) var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid)) var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
position: absolute;
left: 100%;
bottom: calc(0px - var(--navigation-border-bottom-width));
}
.vector-menu-tabs .mw-list-item + .mw-list-item,
.vector-menu-dropdown {
margin-left: calc(min(0px, var(--wiki-navigation-tab-spacing)));
}
.vector-menu-tabs .mw-list-item a,
.vector-menu-tabs .mw-list-item a:visited,
#mw-head .vector-menu-dropdown .vector-menu-heading { /* "#mw-head " is needed here to correctly overwriting mw default css */
/* inner box of normal tabs: tab style */
float: none;
height: auto;
margin: 0;
padding: var(--wiki-navigation-tab-padding-top, 1.25em) var(--wiki-navigation-tab-padding-x, 0.75em) var(--wiki-navigation-tab-padding-bottom, 4px);
border: var(--wiki-navigation-border-width, 1px) var(--wiki-navigation-border-style, solid) var(--wiki-navigation-border-color);
border-bottom-width: calc(min(var(--wiki-navigation-bottom-spacing, 0px)*999, var(--wiki-navigation-border-width, 1px)));
border-radius: var(--wiki-navigation-border-radius) var(--wiki-navigation-border-radius) 0 0;
border-image: var(--wiki-navigation-border-image);
color: var(--wiki-navigation-text-color);
background-image: var(--wiki-navigation-background-image, none);
background-color: color-mix(in srgb, var(--wiki-navigation-background-color) var(--wiki-navigation-background-opacity), transparent);
background-size: var(--wiki-navigation-background-size, auto);
background-repeat: var(--wiki-navigation-background-repeat, repeat);
background-position: var(--wiki-navigation-background-position, center);
font-size: var(--wiki-navigation-font-size, 0.8125em);
backdrop-filter: var(--wiki-navigation-backdrop-filter, var(--wiki-navigation-selected-backdrop-filter, none));
}
.vector-menu-tabs .mw-list-item a:hover,
#mw-head .vector-menu-dropdown:hover .vector-menu-heading {
border-color: var(--wiki-navigation-border-color--hover, var(--wiki-navigation-border-color));
color: var(--wiki-navigation-text-color--hover);
border-image: var(--wiki-navigation-border-image--hover);
background-image: var(--wiki-navigation-background-image--hover, var(--wiki-navigation-background-image, none));
background-color: color-mix(in srgb, var(--wiki-navigation-background-color--hover, var(--wiki-navigation-background-color)) var(--wiki-navigation-background-opacity--hover, var(--wiki-navigation-background-opacity)), transparent);
background-size: var(--wiki-navigation-background-size--hover, var(--wiki-navigation-background-size, auto));
background-repeat: var(--wiki-navigation-background-repeat--hover, var(--wiki-navigation-background-repeat, repeat));
background-position: var(--wiki-navigation-background-position--hover, var(--wiki-navigation-background-position, center));
transform: var(--wiki-navigation-transform--hover, none);
}
.vector-menu-tabs .mw-list-item.selected {
background: none;
border-bottom-color: transparent;
}
.vector-menu-tabs .mw-list-item.selected a {
/* inner box of selected tab: tab style */
background-image: var(--wiki-navigation-selected-background-image, none);
background-color: color-mix(in srgb, var(--wiki-navigation-selected-background-color) var(--wiki-navigation-selected-background-opacity), transparent);
background-size: var(--wiki-navigation-selected-background-size, auto);
background-repeat: var(--wiki-navigation-selected-background-repeat, repeat);
background-position: var(--wiki-navigation-selected-background-position, center);
border: var(--wiki-navigation-selected-border-width, 1px) var(--wiki-navigation-selected-border-style, solid) var(--wiki-navigation-selected-border-color);
border-bottom-width: calc(min(var(--wiki-navigation-bottom-spacing, 0px)*999, var(--wiki-navigation-selected-border-width, 1px)));
border-image: var(--wiki-navigation-selected-border-image);
color: var(--wiki-navigation-selected-text-color);
backdrop-filter: var(--wiki-navigation-selected-backdrop-filter, none);
}
.vector-menu-tabs .mw-list-item.selected::before {
content: '';
display: block;
width: 100%;
box-sizing: border-box;
height: var(--navigation-border-bottom-width);
border: var(--wiki-navigation-selected-border-width, var(--wiki-content-border-width, 1px)) var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid)) var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
border-top-width: 0;
border-bottom-width: 0;
position: absolute;
bottom: calc(0px - var(--navigation-border-bottom-width));
background: var(--wiki-navigation-selected-border-bottom-background, transparent);
background-clip: padding-box;
}
/* watch/unwatch star */
.vector-menu-tabs #ca-watch.icon a,
.vector-menu-tabs #ca-unwatch.icon a {
width: var(--wiki-navigation-icon-size, 1em);
height: 100%;
box-sizing: content-box;
padding: var(--wiki-navigation-tab-padding-top, 1.25em) var(--wiki-navigation-tab-padding-x--icon, var(--wiki-navigation-tab-padding-x, 0.75em)) var(--wiki-navigation-tab-padding-bottom, 4px) var(--wiki-navigation-tab-padding-x--icon, var(--wiki-navigation-tab-padding-x, 0.75em));
color: transparent; /* for watch/unwatch, the text of <a> will be plain 'watch'/'unwatch' without <span> after clicking. */
display: flex;
align-items: center;
text-indent: 999px;
}
.vector-menu-tabs #ca-watch.icon a::before,
.vector-menu-tabs #ca-unwatch.icon a::before {
content: "";
display: block;
position: unset;
background-image: none !important;
width: var(--wiki-navigation-icon-size, 1em);
height: var(--wiki-navigation-icon-size, 1em);
flex: 0 0 auto;
--mask: var(--icon) no-repeat;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background-color: var(--wiki-navigation-text-color);
}
.vector-menu-tabs #ca-watch.icon a:hover::before,
.vector-menu-tabs #ca-unwatch.icon a:hover::before {
background-color: var(--wiki-navigation-text-color--hover);
}
.vector-menu-tabs #ca-unwatch.icon .loading::before,
.vector-menu-tabs #ca-watch.icon .loading::before{
transform-origin: 50% 56.25%;
}
.vector-menu-tabs #ca-watch.icon {
/* line star */
--icon: var(--icon-star-empty);
}
.vector-menu-tabs #ca-unwatch.icon {
/* solid star */
--icon: var(--icon-star-filled);
}
/*** dropdown menu ***/
.vector-menu-dropdown .vector-menu-heading { /* "More" */
/* tab label */
position: relative;
display: flex;
align-items: center;
gap: 0.25em;
}
.vector-menu-dropdown .vector-menu-heading::after {
/* arrow icon */
content: "";
display: block;
width: 1em;
height: 1em;
margin-top: 1px; /* tweak offset */
--mask: var(--icon-chevron-down) no-repeat;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background: unset;
background-color: var(--wiki-navigation-text-color);
filter: none;
}
.vector-menu-dropdown:hover .vector-menu-heading::after {
/* .vector-menu-heading is covered by .vector-menu-checkbox, therefore we can't use .vector-menu-heading:hover::after */
background-color: var(--wiki-navigation-text-color--hover);
}
.vector-menu-dropdown .mw-list-item a:not(.vector-icon) {
font-size: var(--wiki-navigation-dropdown-font-size, 0.8125em);
}
.vector-menu-dropdown .vector-menu-content {
/* dropdown list body */
border: none;
background: none;
left: 0; /* reset */
margin: 0; /* reset */
top: calc(100% - var(--wiki-navigation-bottom-spacing, 0px));
overflow: unset;
}
.vector-menu-dropdown .vector-menu-content ul {
border: var(--wiki-navigation-dropdown-border-width) solid var(--wiki-navigation-dropdown-border-color);
border-radius: 0 0 var(--wiki-navigation-dropdown-border-radius) var(--wiki-navigation-dropdown-border-radius);
border-image: var(--wiki-navigation-dropdown-border-image);
background: color-mix(in srgb, var(--wiki-navigation-dropdown-background-color, var(--wiki-content-background-color)) var(--wiki-navigation-dropdown-background-opacity, var(--wiki-content-background-opacity, 100%)), transparent);
box-shadow: var(--wiki-navigation-dropdown-box-shadow, var(--wiki-navigation-dropdown-shadow, none)); /* --wiki-navigation-dropdown-shadow is deprecated name */
backdrop-filter: var(--wiki-navigation-dropdown-backdrop-filter);
padding: var(--wiki-navigation-dropdown-padding, 0);
margin-top: var(--wiki-navigation-dropdown-offset, 0);
}
.vector-menu-dropdown .vector-menu-content li:hover {
background: var(--wiki-navigation-dropdown-item-background--hover, none);
}
.vector-menu-dropdown .vector-menu-content li a {
display: block;
padding: var(--wiki-navigation-dropdown-item-padding, 0);
}
.vector-menu-dropdown .vector-menu-content li a,
.vector-menu-dropdown .vector-menu-content li a:visited {
color: var(--wiki-navigation-dropdown-text-color, var(--wiki-navigation-text-color));
}
.vector-menu-dropdown .vector-menu-content li a:hover {
color: var(--wiki-navigation-dropdown-text-color--hover, var(--wiki-navigation-text-color--hover, var(--wiki-content-link-color--hover))); /* fallback for backwards compatibility */
}
/*** search form ***/
#p-search {
margin: 0;
padding: 0 calc(max(0px, var(--wiki-navigation-right-spacing, 0px))) calc(var(--wiki-navigation-search-bottom-spacing, 3px) + var(--navigation-border-bottom-width)) calc(max(0px, 3px - max(0px, var(--wiki-navigation-tab-spacing, -1px))));
z-index: 2;
position: relative;
font-size: var(--wiki-navigation-search-font-size, var(--wiki-navigation-font-size, 0.8125em));
}
.vector-search-box form {
margin: unset;
}
#p-search .searchButton {
background-color: transparent;
font-size: unset;
}
/*new search form */
.cdx-search-input--has-end-button .cdx-search-input__input-wrapper{
margin: 0;
}
.cdx-menu-item--enabled.cdx-menu-item--highlighted {
background-color: var(--wiki-navigation-search-highlight-background-color);
}
#p-search input{
line-height: 1.25; /* "normal" behaves inconsistently in different browsers */
}
#p-search input{
height: unset;
min-height: var(--wiki-navigation-search-height, 2em);
}
#p-search button{
height: unset;
min-height: var(--wiki-navigation-search-height, 2em);
min-width: var(--wiki-navigation-search-height, 2em);
top: 0;
bottom: 0;
right: 0;
background-color: color-mix(in srgb, var(--wiki-navigation-search-button-color, currentColor) var(--wiki-navigation-search-button-color-opacity, 80%), transparent);
opacity: 100%;
}
#p-search button:hover,
#p-search button:focus{
background-color: color-mix(in srgb, var(--wiki-navigation-search-button-color--hover, var(--wiki-navigation-search-button-color, currentColor)) var(--wiki-navigation-search-button-color-opacity--hover, 95%), transparent);
opacity: 100%;
}
/* top border of the content box */
#p-search::before {
content: "";
display: block;
width: calc(100% - calc(max(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0)), var(--navigation-border-bottom-width))));
height: 0;
border-bottom: var(--navigation-border-bottom-width) var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid)) var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
position: absolute;
bottom: 0;
left: 0;
}
/* top right border-radius of content area */
#p-search::after {
content: "";
display: block;
width: calc(max(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0)), var(--navigation-border-bottom-width)));
height: calc(max(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0)), var(--navigation-border-bottom-width)));
box-sizing: border-box;
border-width: var(--navigation-border-bottom-width) var(--navigation-border-bottom-width) 0 0;
border-style: var(--wiki-navigation-border-bottom-style, var(--wiki-navigation-selected-border-style, solid));
border-color: var(--wiki-navigation-border-bottom-color, var(--wiki-navigation-selected-border-color));
border-radius: 0 calc(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0))) 0 0;
position: absolute;
top: calc(100% - var(--navigation-border-bottom-width));
right: 0;
}
/******************
* End vector tabs *
*******************/
/********
* Links *
*********/
a,
.mw-parser-output a.external,
.mw-parser-output a.extiw {
color: var(--wiki-content-link-color);
}
a:visited,
.mw-parser-output a.extiw:visited,
.mw-parser-output a.external:visited {
color: var(--wiki-content-link-color--visited);
}
a:not(.mw-selflink):hover,
a:visited:hover,
.mw-parser-output a.extiw:hover,
.mw-parser-output a.extiw:visited:hover,
.mw-parser-output a.external:hover,
.mw-parser-output a.external:visited:hover {
color: var(--wiki-content-link-color--hover);
}
a.new,
a.new:visited,
a.new:hover,
.mw-usertoollinks-contribs-no-edits {
color: var(--wiki-content-redlink-color);
}
a:not(.mw-selflink):active,
a:visited:active,
.mw-parser-output a.extiw:active,
.mw-parser-output a.extiw:visited:active,
.mw-parser-output a.external:active,
.mw-parser-output a.external:visited:active {
color: var(--wiki-warning-color);
}
/* link decorations */
/* move external marker to an after so we can filter it to link color */
.mw-parser-output a.external,
.sitenotice a.external {
background: none;
padding-right: 0;
}
.mw-parser-output a.external::after,
.sitenotice a.external::after,
a.extiw[title="wgg:globalprefs"]::after {
display: inline-block;
width: 1em;
height: 1em;
margin-left: 0px;
content: '';
vertical-align: text-top;
--mask: var(--icon) no-repeat;
--mask-size: 0.857em;
--mask-position: center right;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: var(--mask-size);
mask-size: var(--mask-size);
-webkit-mask-position: var(--mask-position);
mask-position: var(--mask-position);
background-color: currentColor;
}
.mw-parser-output a.external::after,
.sitenotice a.external::after {
--icon: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2212%22 height=%2212%22 viewBox=%220 0 12 12%22%3E %3Cpath d=%22M6 1h5v5L8.86 3.85 4.7 8 4 7.3l4.15-4.16L6 1ZM2 3h2v1H2v6h6V8h1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1Z%22/%3E %3C/svg%3E");
}
a.extiw[title="wgg:globalprefs"]::after {
--icon: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%20aria-hidden%3D%22true%22%3E%3C!----%3E%3Cg%3E%3Cg%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20transform%3D%22translate(10%2010)%22%3E%3Cpath%20id%3D%22cdx-icon-settings-a%22%20d%3D%22M1.5-10h-3l-1%206.5h5m0%207h-5l1%206.5h3%22%3E%3C%2Fpath%3E%3Cuse%20xlink%3Ahref%3D%22%23cdx-icon-settings-a%22%20transform%3D%22rotate(45)%22%3E%3C%2Fuse%3E%3Cuse%20xlink%3Ahref%3D%22%23cdx-icon-settings-a%22%20transform%3D%22rotate(90)%22%3E%3C%2Fuse%3E%3Cuse%20xlink%3Ahref%3D%22%23cdx-icon-settings-a%22%20transform%3D%22rotate(135)%22%3E%3C%2Fuse%3E%3C%2Fg%3E%3Cpath%20d%3D%22M10%202.5a7.5%207.5%200%20000%2015%207.5%207.5%200%20000-15v4a3.5%203.5%200%20010%207%203.5%203.5%200%20010-7%22%3E%3C%2Fpath%3E%3C%2Fg%3E%3C%2Fsvg%3E");
}
.plainlinks a.external::after,
.plainlinks a.extiw[title="wgg:globalprefs"]::after {
display: none;
}
/*
Using a background instead of an ::after prevents the icon from wrapping onto its own line,
but prevents it from being recolored. Use this only for icons that should not be recolored, otherwise
use the ::after method used for external links above
*/
a.extiw[title^="wikipedia:"],
a.extiw[title^="wp:"],
a.extiw[title^="mw:"],
a.extiw[title^="support:"] {
padding-right: 1em;
background-position: center right;
background-repeat: no-repeat;
background-size: 0.857em;
}
a.extiw[title^="wikipedia:"],
a.extiw[title^="wp:"] {
background-image: url(https://commons.wiki.gg/images/2/28/Wikipedia.svg?202406)
}
a.extiw[title^="mw:"] {
background-image: url(https://commons.wiki.gg/images/9/9b/MediaWiki.svg?202406)
}
a.extiw[title^="support:"] {
background-image: url(https://commons.wiki.gg/images/9/9b/Wiki.gg_icon-pink.svg)
}
.plainlinks a.extiw {
background-image:none;
}
/************
* End links *
*************/
/***************
* Left Sidebar *
****************/
#mw-panel {
width: var(--wiki-sidebar-width, 10em);
box-sizing: border-box;
position: relative;
z-index: 1; /* above #footer */
top: calc(-1 * var(--wiki-is-navigation-inside-content, 0) * (var(--wiki-navigation-height) + var(--wiki-content-border-width,1px)) + var(--wiki-sidebar-offset, 0px));
margin-top: calc((1 - var(--wiki-is-top-logo, 0)) * (var(--wiki-logo-file-height, 160) / var(--wiki-logo-file-width, 160) * var(--wiki-sidebar-width, 10em) + var(--wiki-logo-margin, 15px))); /* if is-top-logo, logo-file ratio * sidebar-width + logo-margin, else 0 */
padding: var(--wiki-sidebar-box-padding, 0);
background: var(--wiki-sidebar-box-background, none);
border: var(--wiki-sidebar-box-border, 0);
border-image: var(--wiki-sidebar-box-border-image, none);
}
#mw-panel .vector-menu-portal {
background-color: color-mix(in srgb, var(--wiki-sidebar-background-color) var(--wiki-sidebar-background-opacity), transparent);
background-image: var(--wiki-sidebar-background-image, none);
background-size: var(--wiki-sidebar-background-size, auto);
background-repeat: var(--wiki-sidebar-background-repeat, repeat);
background-position: var(--wiki-sidebar-background-position, center);
border: var(--wiki-sidebar-border-width, 1px) var(--wiki-sidebar-border-style, solid) var(--wiki-sidebar-border-color);
border-image: var(--wiki-sidebar-border-image, none);
margin: 0 var(--wiki-sidebar-margin, 0.5em);
padding: var(--wiki-sidebar-padding, 0);
filter: var(--wiki-sidebar-filter, none);
backdrop-filter: var(--wiki-sidebar-backdrop-filter, none);
overflow: hidden; /* to prevent overflow when combining border-radius with heading background */
}
#mw-panel #p-ext-discordwidget{
backdrop-filter: none;
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
#mw-panel .vector-menu-portal {
background-color: var(--wiki-sidebar-background-color);
}
}
#mw-panel .vector-menu-portal + .vector-menu-portal {
border-top-width: 0;
}
#mw-panel .vector-menu-portal:last-child {
margin-bottom: 0;
}
/* Sidebar spacing and border-radius section */
#mw-panel .vector-menu-portal:not(:last-child) {
margin-bottom: var(--wiki-sidebar-portal-spacing);
}
#mw-panel #p-logo + .vector-menu-portal,
#mw-panel #p-ext-discordwidget + .vector-menu-portal {
/*
The way this works is that if the sidebar does not have any spacing, only the top and bottom corners
of the top and bottom portals respectively should be rounded, instead of all corners of every portal.
min and calc are combined here to basically create an `if x > 0 then y else z` function.
The lower of (sidebar-border-radius) and (spacing * 999) are compared and the smaller value is taken (999 is simply an arbitrary large number).
If portal spacing is zero, multiplying it gets 0 and will be the smaller value. If it's non-zero, it will be large and sidebar-border-radius will be the smaller value.
This is only applied to the "inner" corners because we'd want the "outer" corners rounded in either scenario.
*/
border-radius: var(--wiki-sidebar-border-radius) var(--wiki-sidebar-border-radius) calc(min(var(--wiki-sidebar-border-radius), var(--wiki-sidebar-portal-spacing) * 999)) calc(min(var(--wiki-sidebar-border-radius), var(--wiki-sidebar-portal-spacing) * 999));
}
#mw-panel .vector-menu-portal:last-child {
/* see rule above for explanation */
border-radius: calc(min(var(--wiki-sidebar-border-radius), var(--wiki-sidebar-portal-spacing) * 999)) calc(min(var(--wiki-sidebar-border-radius), var(--wiki-sidebar-portal-spacing) * 999)) var(--wiki-sidebar-border-radius) var(--wiki-sidebar-border-radius);
}
#mw-panel .vector-menu-portal {
/* see above rules for explanation */
border-radius: calc(min(var(--wiki-sidebar-border-radius), var(--wiki-sidebar-portal-spacing) * 999));
}
#mw-panel .vector-menu-portal + .vector-menu-portal {
/* This keeps the border from doubling up if there is no spacing between them,
The portals other than the first only have a top border if there is spacing */
border-top-width: min(var(--wiki-sidebar-border-width, 1px), var(--wiki-sidebar-portal-spacing, 0px)); /* the 1px and 0px fallbacks are for backwards compatibility with older versions of the loadout */
}
#mw-panel #p-ext-discordwidget + .vector-menu-portal {
border-top-width: var(--wiki-sidebar-border-width, 1px);
}
/* end sidebar spacing and border-radius */
.vector-menu-portal .vector-menu-heading {
padding: var(--wiki-sidebar-heading-padding, 0.5rem 0.25rem 0.5rem 0.5rem);
margin: var(--wiki-sidebar-heading-margin, 0 0 var(--wiki-sidebar-heading-margin-bottom, -0.5rem) 0); /* --wiki-sidebar-heading-margin-bottom is deprecated */
background: var(--wiki-sidebar-heading-background, none);
border-image: var(--wiki-sidebar-heading-border-image, none);
color: var(--wiki-sidebar-heading-color);
font-family: var(--wiki-sidebar-heading-font-family);
font-size: var(--wiki-sidebar-heading-font-size, 0.75em);
font-weight: var(--wiki-sidebar-heading-font-weight, normal);
font-style: var(--wiki-sidebar-heading-font-style, normal);
text-transform: var(--wiki-sidebar-heading-text-transform, none);
line-height: var(--wiki-sidebar-heading-line-height, normal);
text-shadow: var(--wiki-sidebar-heading-text-shadow, none)
}
.vector-menu-portal .vector-menu-content {
margin: var(--wiki-sidebar-list-margin, 0);
padding: var(--wiki-sidebar-list-padding, 0.25rem);
background: var(--wiki-sidebar-list-background, none);
border-image: var(--wiki-sidebar-list-border-image, none);
}
.vector-menu-portal .vector-menu-content ul {
padding: 0;
display: flex;
flex-direction: column;
gap: var(--wiki-sidebar-list-item-spacing, 0);
}
.vector-menu-portal .vector-menu-content li {
font-size: var(--wiki-sidebar-font-size, 0.75em);
line-height: var(--wiki-sidebar-line-height, 1.125em);
padding: 0;
background: var(--wiki-sidebar-list-item-background, none);
border-image: var(--wiki-sidebar-list-item-border-image, none);
}
.vector-menu-portal .vector-menu-content li:hover {
background: var(--wiki-sidebar-list-item-background--hover, var(--wiki-sidebar-list-item-background, none));
border-image: var(--wiki-sidebar-list-item-border-image--hover, var(--wiki-sidebar-list-item-border-image, none));
}
.vector-menu-portal .vector-menu-content li a {
display: block;
padding: var(--wiki-sidebar-list-item-padding, 0.25em 0.25rem);
}
.vector-menu-portal .vector-menu-content li a.feedlink{ /* Atom */
background: none;
}
.vector-menu-portal .vector-menu-content .mw-list-item a,
.vector-menu-portal .vector-menu-content .mw-list-item a:visited,
.vector-menu-portal .vector-menu-content li a,
.vector-menu-portal .vector-menu-content li a:visited {
color: var(--wiki-sidebar-link-color);
}
.vector-menu-portal .vector-menu-content .mw-list-item a:hover,
.vector-menu-portal .vector-menu-content .mw-list-item a:visited:hover {
color: var(--wiki-sidebar-link-color--hover, var(--wiki-content-link-color--hover)); /* fallback for backwards compatibility */
}
#t-newpage {
--sidebar-icon: url('data:image/svg+xml;charset=UTF-8,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 384 512%22%3E%3C!--%21Font Awesome Free 6.5.2 by %40fontawesome - https%3A%2F%2Ffontawesome.com License - https%3A%2F%2Ffontawesome.com%2Flicense%2Ffree Copyright 2024 Fonticons%2C Inc.--%3E%3Cpath d%3D%22M0 64C0 28.7 28.7 0 64 0H224V128c0 17.7 14.3 32 32 32H384V448c0 35.3-28.7 64-64 64H64c-35.3 0-64-28.7-64-64V64zm384 64H256V0L384 128z%22%2F%3E%3C%2Fsvg%3E');
order: -1;
}
#t-upload {
--sidebar-icon: url('data:image/svg+xml;charset=UTF-8,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 512 512%22%3E%3C!--%21Font Awesome Free 6.5.2 by %40fontawesome - https%3A%2F%2Ffontawesome.com License - https%3A%2F%2Ffontawesome.com%2Flicense%2Ffree Copyright 2024 Fonticons%2C Inc.--%3E%3Cpath d%3D%22M288 109.3V352c0 17.7-14.3 32-32 32s-32-14.3-32-32V109.3l-73.4 73.4c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l128-128c12.5-12.5 32.8-12.5 45.3 0l128 128c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L288 109.3zM64 352H192c0 35.3 28.7 64 64 64s64-28.7 64-64H448c35.3 0 64 28.7 64 64v32c0 35.3-28.7 64-64 64H64c-35.3 0-64-28.7-64-64V416c0-35.3 28.7-64 64-64zM432 456a24 24 0 1 0 0-48 24 24 0 1 0 0 48z%22%2F%3E%3C%2Fsvg%3E');
order: -1;
}
#t-print {
--sidebar-icon: url('data:image/svg+xml;charset=UTF-8,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 512 512%22%3E%3C!--%21Font Awesome Free 6.5.2 by %40fontawesome - https%3A%2F%2Ffontawesome.com License - https%3A%2F%2Ffontawesome.com%2Flicense%2Ffree Copyright 2024 Fonticons%2C Inc.--%3E%3Cpath d%3D%22M128 0C92.7 0 64 28.7 64 64v96h64V64H354.7L384 93.3V160h64V93.3c0-17-6.7-33.3-18.7-45.3L400 18.7C388 6.7 371.7 0 354.7 0H128zM384 352v32 64H128V384 368 352H384zm64 32h32c17.7 0 32-14.3 32-32V256c0-35.3-28.7-64-64-64H64c-35.3 0-64 28.7-64 64v96c0 17.7 14.3 32 32 32H64v64c0 35.3 28.7 64 64 64H384c35.3 0 64-28.7 64-64V384zM432 248a24 24 0 1 1 0 48 24 24 0 1 1 0-48z%22%2F%3E%3C%2Fsvg%3E');
order: -1;
}
#t-whatlinkshere {
--sidebar-icon: url('data:image/svg+xml;charset=UTF-8,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 640 512%22%3E%3C!--%21Font Awesome Free 6.5.2 by %40fontawesome - https%3A%2F%2Ffontawesome.com License - https%3A%2F%2Ffontawesome.com%2Flicense%2Ffree Copyright 2024 Fonticons%2C Inc.--%3E%3Cpath d%3D%22M579.8 267.7c56.5-56.5 56.5-148 0-204.5c-50-50-128.8-56.5-186.3-15.4l-1.6 1.1c-14.4 10.3-17.7 30.3-7.4 44.6s30.3 17.7 44.6 7.4l1.6-1.1c32.1-22.9 76-19.3 103.8 8.6c31.5 31.5 31.5 82.5 0 114L422.3 334.8c-31.5 31.5-82.5 31.5-114 0c-27.9-27.9-31.5-71.8-8.6-103.8l1.1-1.6c10.3-14.4 6.9-34.4-7.4-44.6s-34.4-6.9-44.6 7.4l-1.1 1.6C206.5 251.2 213 330 263 380c56.5 56.5 148 56.5 204.5 0L579.8 267.7zM60.2 244.3c-56.5 56.5-56.5 148 0 204.5c50 50 128.8 56.5 186.3 15.4l1.6-1.1c14.4-10.3 17.7-30.3 7.4-44.6s-30.3-17.7-44.6-7.4l-1.6 1.1c-32.1 22.9-76 19.3-103.8-8.6C74 372 74 321 105.5 289.5L217.7 177.2c31.5-31.5 82.5-31.5 114 0c27.9 27.9 31.5 71.8 8.6 103.9l-1.1 1.6c-10.3 14.4-6.9 34.4 7.4 44.6s34.4 6.9 44.6-7.4l1.1-1.6C433.5 260.8 427 182 377 132c-56.5-56.5-148-56.5-204.5 0L60.2 244.3z%22%2F%3E%3C%2Fsvg%3E');
order: -1;
}
#t-specialpages {
--sidebar-icon: url('data:image/svg+xml;charset=UTF-8,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 576 512%22%3E%3C!--%21Font Awesome Free 6.5.2 by %40fontawesome - https%3A%2F%2Ffontawesome.com License - https%3A%2F%2Ffontawesome.com%2Flicense%2Ffree Copyright 2024 Fonticons%2C Inc.--%3E%3Cpath d%3D%22M316.9 18C311.6 7 300.4 0 288.1 0s-23.4 7-28.8 18L195 150.3 51.4 171.5c-12 1.8-22 10.2-25.7 21.7s-.7 24.2 7.9 32.7L137.8 329 113.2 474.7c-2 12 3 24.2 12.9 31.3s23 8 33.8 2.3l128.3-68.5 128.3 68.5c10.8 5.7 23.9 4.9 33.8-2.3s14.9-19.3 12.9-31.3L438.5 329 542.7 225.9c8.6-8.5 11.7-21.2 7.9-32.7s-13.7-19.9-25.7-21.7L381.2 150.3 316.9 18z%22%2F%3E%3C%2Fsvg%3E');
order: -1;
}
#t-cargopagevalueslink {
--sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 126.971 136.024'%3E%3Cpath d='m105.999 0-84 .049L0 8.957v127.065h126.97V8.957Z' fill='none' display='inline' opacity='1' paint-order='normal'/%3E%3Cpath d='m9.735 8.774 12.265-5h84l12.25 5H9.75' fill='%23000' fill-opacity='1' display='inline'/%3E%3Cpath d='M3.5 41.024H28v63.5H3.5zm95.5 0h24.5v63.5H99zm-95.5 67.5H123v24H3.5zm0-95.5H123v24H3.5zm27.985 28V59.67l13.61 13.61 17.323 17.324 1.788 1.787 12.131 12.132h19.147v-16.21l-13.6-13.6-1.788-1.787-17.325-17.324-14.578-14.579H31.485zm45.865 0-12.2 12.2 17.324 17.324 13.01-13.01V41.024H77.35zM42.716 75.658l-11.23 11.231v17.634h17.013l11.541-11.54-17.324-17.325z' fill='%23000' fill-opacity='1' fill-rule='nonzero' display='inline' opacity='1' paint-order='normal'/%3E%3C/svg%3E");
order: -1;
}
#feedlinks{
--sidebar-icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg baseProfile='tiny' height='24px' id='Layer_1' version='1.2' viewBox='0 0 24 24' width='24px' xml:space='preserve' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cpath d='M6.002,15.999C4.895,15.999,3.998,16.896,4,18c0,1.104,0.896,2.001,2.002,1.999C7.105,20.001,8.002,19.105,8,18 C8.002,16.893,7.105,15.997,6.002,15.999z'/%3E%3Cpath d='M6,4C4.896,4,4,4.896,4,6s0.896,2,2,2c5.514,0,10,4.486,10,10c0,1.104,0.896,2,2,2s2-0.896,2-2C20,10.28,13.72,4,6,4z'/%3E%3Cpath d='M6,10c-1.104,0-2,0.896-2,2s0.896,2,2,2c2.205,0,4,1.794,4,4c0,1.104,0.896,2,2,2s2-0.896,2-2C14,13.589,10.411,10,6,10z'/%3E%3C/svg%3E");
order: -1;
}
#t-specialpages > a::before,
#t-whatlinkshere > a::before,
#t-print > a::before,
#t-newpage > a::before,
#t-upload > a::before,
#t-cargopagevalueslink > a::before,
#feedlinks > a::before {
content: '';
background-image: var(--sidebar-icon);
background-size: contain;
background-repeat: no-repeat;
background-position: center;
display: inline-block;
width: 1.25em;
height: 1.25em;
}
#p-tb .mw-list-item > a::before {
filter: var(--wiki-sidebar-icon-to-link-filter, var(--wiki-icon-to-link-filter));
}
#p-tb .mw-list-item > a {
display: flex;
align-items: center;
gap: 3px;
}
/*******************
* End left sidebar *
********************/
/*******
* Logo *
********/
/* [[File:Site-logo.png]] */
#p-logo {
width: var(--wiki-logo-box-width);
height: var(--wiki-logo-box-height);
position: absolute;
top: calc(-1 * ( (var(--wiki-navigation-height, 3rem) + var(--wiki-logo-box-height) + var(--wiki-logo-margin, 15px) - var(--wiki-is-navigation-inside-content, 0) * (var(--wiki-navigation-height)) + var(--wiki-sidebar-offset, 0px)) * var(--wiki-is-top-logo, 0)
+ (var(--wiki-logo-box-height) + var(--wiki-logo-margin,15px)) * (1 - var(--wiki-is-top-logo, 0)) ));
left: calc((min((100vw - var(--wiki-left-spacing, 0.5em) - var(--wiki-right-spacing, 0px) - 18px), var(--wiki-page-content-max-width, 9999px)) - var(--wiki-logo-box-width)) / 2 * var(--wiki-is-top-logo, 0));
margin: 0;
filter: var(--wiki-logo-filter, none);
}
#p-logo a {
background-size: contain;
position: absolute;
top: var(--wiki-logo-offset-y, 0);
left: var(--wiki-logo-offset-x, 0);
bottom: 0;
right: 0;
width: 100%;
height: 100%;
background-image: var(--wiki-logo-image, url(filepath://Site-logo.png)); /* The canonical logo must be Site-logo.png. This variable is mainly used to provide different logo for different themes. */
}
/***********
* End logo *
************/
/***************
* Content area *
****************/
.content-wrapper {
max-width: var(--wiki-page-content-max-width, none);
margin-left: auto;
margin-right: auto;
}
.mw-body,
.parsoid-body {
color: var(--wiki-content-text-color);
background-color: color-mix(in srgb, var(--wiki-content-background-color) var(--wiki-content-background-opacity), transparent);
margin-left: calc(var(--wiki-sidebar-width, 10em) + var(--wiki-gap-between-sidebar-and-content, 0.5em));
margin-top: unset;
border-top: 0;
border-left: var(--wiki-content-border-width, 1px) solid transparent;
border-right: var(--wiki-content-border-width, 1px) solid transparent;
border-bottom: var(--wiki-content-border-bottom-width, 1px) solid transparent;
border-radius: calc((1 - var(--wiki-is-navigation-inside-content, 0)) * min(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)), var(--wiki-navigation-left-spacing, 0px))) calc((1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px))) calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-content-border-radius, 0px))) calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-content-border-radius, 0px)));
position: relative;
border-image: var(--wiki-content-border-image, none);
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.mw-body,
.parsoid-body {
background-color: var(--wiki-content-background-color);
}
}
/* apply backdrop-filter on .mw-body results in the creation of a containing block for absolute and fixed positioned descendants, so we have to move it to here */
.mw-body::before,
.parsoid-body::before{
content: '';
display: block;
backdrop-filter: var(--wiki-content-backdrop-filter, none);
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
z-index: -1;
border-radius: calc((1 - var(--wiki-is-navigation-inside-content, 0)) * min(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)), var(--wiki-navigation-left-spacing, 0px))) calc((1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px))) calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-content-border-radius, 0px))) calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-content-border-radius, 0px))); /* as .mw-body */
}
.mw-body::after,
.parsoid-body::after {
content: '';
display: block;
box-sizing: border-box;
position: absolute;
left: calc(-1 * var(--wiki-content-border-width, 1px));
right: calc(-1 * var(--wiki-content-border-width, 1px));
top: calc(var(--wiki-content-border-top-radius, var(--wiki-content-border-radius, 0px)) * (1 - var(--wiki-is-navigation-inside-content, 0)));
bottom: calc(-1 * var(--wiki-content-border-bottom-width, 1px));
pointer-events: none;
border-left: var(--wiki-content-border-width, 1px) var(--wiki-content-border-style, solid) var(--wiki-content-border-color);
border-right: var(--wiki-content-border-width, 1px) var(--wiki-content-border-style, solid) var(--wiki-content-border-color);
border-bottom: var(--wiki-content-border-bottom-width, 1px) var(--wiki-content-border-bottom-style, solid) var(--wiki-content-border-bottom-color, var(--wiki-content-border-color));
border-radius: 0 0 calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-content-border-radius, 0px))) calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-content-border-radius, 0px)));
}
#mw-data-after-content {
max-width: calc(var(--wiki-page-content-max-width) - var(--wiki-sidebar-width) - var(--wiki-gap-between-sidebar-and-content));
margin-left: calc(var(--wiki-sidebar-width) + var(--wiki-gap-between-sidebar-and-content) + max(0px, 100% - var(--wiki-page-content-max-width)) / 2);
box-sizing: border-box;
color: var(--wiki-content-text-color);
background-color: color-mix(in srgb, var(--wiki-content-background-color) var(--wiki-content-background-opacity), transparent);
}
#mw-data-after-content .read-more-container {
border: var(--wiki-content-border-width, 1px) var(--wiki-content-border-style, solid) var(--wiki-content-border-color);
border-top-width: 0;
border-bottom: var(--wiki-content-border-bottom-width, 1px) var(--wiki-content-border-bottom-style, solid) var(--wiki-content-border-bottom-color, var(--wiki-content-border-color));
padding: 1em;
margin: 0;
}
#mw-data-after-content .read-more-container:empty {
display: none;
}
@media screen and (min-width: 982px) {
#mw-data-after-content .read-more-container {
padding: 1.25em 1.5em 1.5em 1.5em;
}
}
.mw-footer {
max-width: calc(var(--wiki-page-content-max-width, 9999px) - var(--wiki-sidebar-width, 10em) - var(--wiki-gap-between-sidebar-and-content, 0.5em));
box-sizing: border-box;
background-color: color-mix(in srgb, var(--wiki-footer-background-color, var(--wiki-content-background-color)) var(--wiki-footer-background-opacity, var(--wiki-content-background-opacity)), transparent);
border: var(--wiki-footer-border-width, 1px) var(--wiki-footer-border-style, solid) var(--wiki-footer-border-color, var(--wiki-content-border-color));
border-top-width: calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-footer-border-width, 1px)));
margin-top: var(--wiki-spacing-before-footer, 0px);
border-radius: calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-footer-border-radius, var(--wiki-content-border-radius, 0px)))) calc(min(var(--wiki-spacing-before-footer, 0px) * 999, var(--wiki-footer-border-radius, var(--wiki-content-border-radius, 0px)))) var(--wiki-footer-border-radius, var(--wiki-content-border-radius, 0px)) var(--wiki-footer-border-radius, var(--wiki-content-border-radius, 0px));
margin-left: calc(var(--wiki-sidebar-width, 10em) + var(--wiki-gap-between-sidebar-and-content, 0.5em) + max(0px, 100% - var(--wiki-page-content-max-width, 9999px)) / 2);
color: var(--wiki-footer-text-color);
border-image: var(--wiki-footer-border-image, none);
backdrop-filter: var(--wiki-footer-backdrop-filter, none);
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.mw-footer {
background-color: var(--wiki-footer-background-color, var(--wiki-content-background-color));
}
}
.mw-footer li {
color: var(--wiki-footer-text-color);
}
.mw-footer a,
.mw-footer a:visited {
color: var(--wiki-footer-link-color);
}
.mw-footer a:hover,
.mw-footer a:visited:hover {
color: var(--wiki-footer-link-color--hover);
}
/* fix */
@media screen and (max-width: 900px) {
#footer-icons, #footer-places {
clear: unset;
}
}
/*******************************
* End content area and footer *
*******************************/
/***********
* Headings *
************/
.mw-body h1 {
border-bottom: var(--wiki-content-firstheading-border-bottom-width, var(--wiki-content-heading-border-bottom-width, 1px)) var(--wiki-content-firstheading-border-style, var(--wiki-content-heading-border-style, solid)) var(--wiki-content-firstheading-border-color, var(--wiki-content-heading-border-color, var(--wiki-content-border-color)));
font-size: var(--wiki-content-firstheading-font-size, 1.8em);
font-family: var(--wiki-content-firstheading-font-family, var(--wiki-content-heading-font-family));
font-weight: var(--wiki-content-firstheading-font-weight, var(--wiki-content-heading-font-weight));
font-style: var(--wiki-content-firstheading-font-style, var(--wiki-content-heading-font-style));
text-transform: var(--wiki-content-firstheading-text-transform, var(--wiki-content-heading-text-transform));
line-height: var(--wiki-content-firstheading-line-height, var(--wiki-content-heading-line-height));
color: var(--wiki-content-firstheading-color, var(--wiki-content-heading-color));
text-shadow: var(--wiki-content-firstheading-text-shadow, var(--wiki-content-heading-text-shadow, none));
}
.mw-body h2 {
border-bottom: var(--wiki-content-heading-border-bottom-width, 1px) var(--wiki-content-heading-border-style, solid) var(--wiki-content-heading-border-color, var(--wiki-content-border-color));
font-size: var(--wiki-content-heading-h2-font-size, 1.5em);
font-family: var(--wiki-content-heading-font-family);
font-weight: var(--wiki-content-heading-font-weight, normal);
font-style: var(--wiki-content-heading-font-style, normal);
text-transform: var(--wiki-content-heading-text-transform, none);
line-height: var(--wiki-content-heading-line-height, normal);
color: var(--wiki-content-heading-color);
text-shadow: var(--wiki-content-heading-text-shadow, none);
}
.mw-body h3,
.mw-body h4,
.mw-body h5,
.mw-body h6{
border-bottom: var(--wiki-content-subheading-border-bottom-width, 0) var(--wiki-content-subheading-border-style, var(--wiki-content-heading-border-style, solid)) var(--wiki-content-subheading-border-color, var(--wiki-content-heading-border-color, var(--wiki-content-border-color)));
font-family: var(--wiki-content-subheading-font-family, var(--wiki-body-font-family));
font-weight: var(--wiki-content-subheading-font-weight, bold);
font-style: var(--wiki-content-subheading-font-style, normal);
text-transform: var(--wiki-content-subheading-text-transform, none);
line-height: var(--wiki-content-subheading-line-height, var(--wiki-content-heading-line-height));
color: var(--wiki-content-subheading-color, var(--wiki-content-heading-color));
text-shadow: var(--wiki-content-subheading-text-shadow, var(--wiki-content-heading-text-shadow, none));
}
.mw-body h3{
font-size: var(--wiki-content-heading-h3-font-size, 1.2em);
}
.mw-body h4{
font-size: var(--wiki-content-heading-h4-font-size, 114%);
}
.mw-body h5{
font-size: var(--wiki-content-heading-h5-font-size, 108%);
}
.mw-body h6{
font-size: var(--wiki-content-heading-h6-font-size, 100%);
}
.mw-editsection-bracket,
.mw-editsection-divider {
color: var(--wiki-content-heading-color);
}
/***************
* End headings *
****************/
/*************
* Wikitables *
**************/
.wikitable {
background: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.wikitable > tr > th,
.wikitable > * > tr > th {
background: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
}
.wikitable > tr > td,
.wikitable > * > tr > td {
border: 1px solid var(--wiki-content-border-color);
}
/* Forward = yes bg on Special:Interwiki */
table.mw-interwikitable.body td.mw-interwikitable-local-yes {
background: color-mix(in srgb, var(--wiki-success-color) 25%, transparent);
}
.zebra-table > * > tr:nth-of-type(2n),
.zebra-table > tr:nth-of-type(2n) {
background: color-mix(in srgb, var(--wiki-content-dynamic-color--secondary) 5%, transparent);
}
.client-js .sortable:not(.jquery-tablesorter) > * > tr:first-child > th:not(.unsortable),
.jquery-tablesorter th.headerSort {
background-image: unset;
position: relative;
}
.client-js .sortable:not(.jquery-tablesorter) > * > tr:first-child > th:not(.unsortable)::after,
.jquery-tablesorter th.headerSort::after {
content: "";
display: block;
position: absolute;
top: 0;
right: 0;
width: 21px;
height: 100%;
--mask: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2221%22 height=%229%22 viewBox=%220 0 21 9%22%3E %3Cpath d=%22m14.5 5-4 4-4-4zm0-1-4-4-4 4z%22 fill=%22%23fff%22/%3E %3C/svg%3E") no-repeat;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: auto;
mask-size: auto;
-webkit-mask-position: center right;
mask-position: center right;
background-color: var(--wiki-content-link-color);
}
.jquery-tablesorter th.headerSortUp::after {
--mask: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2221%22 height=%224%22 viewBox=%220 0 21 4%22%3E %3Cpath d=%22m6.5 4 4-4 4 4z%22 fill=%22%23fff%22/%3E %3C/svg%3E") no-repeat;
}
.jquery-tablesorter th.headerSortDown::after {
--mask: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2221%22 height=%224%22 viewBox=%220 0 21 4%22%3E %3Cpath d=%22m14.5 0-4 4-4-4z%22 fill=%22%23fff%22/%3E %3C/svg%3E") no-repeat;
}
/*****************
* End wikitables *
******************/
/**************
* Preferences *
***************/
.mw-prefs-tabs-wrapper.oo-ui-panelLayout-framed,
.mw-prefs-tabs > .oo-ui-menuLayout-content > .oo-ui-indexLayout-stackLayout > .oo-ui-tabPanelLayout {
border: none;
}
.oo-ui-tabSelectWidget-framed {
background-color: transparent;
border-bottom: 1px solid var(--wiki-accent-color);
}
.oo-ui-tabSelectWidget-framed .oo-ui-tabOptionWidget.oo-ui-widget-enabled,
.oo-ui-tabSelectWidget-framed .oo-ui-tabOptionWidget.oo-ui-widget-enabled:hover {
background-color: color-mix(in srgb, var(--wiki-accent-label-color) 75%, transparent);
color: var(--wiki-accent-color);
}
.oo-ui-tabSelectWidget-framed .oo-ui-tabOptionWidget.oo-ui-widget-enabled:hover {
color: var(--wiki-accent-color--hover);
}
.oo-ui-tabSelectWidget-framed .oo-ui-tabOptionWidget.oo-ui-optionWidget-selected,
.oo-ui-tabSelectWidget-framed .oo-ui-tabOptionWidget.oo-ui-widget-enabled.oo-ui-optionWidget-selected:hover {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.oo-ui-tabSelectWidget-framed .oo-ui-tabOptionWidget.oo-ui-optionWidget-selected .oo-ui-labelElement-label {
border-bottom: none;
}
#preferences .mw-htmlform-submit-buttons {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.oo-ui-dropdownWidget.oo-ui-widget-enabled .oo-ui-dropdownWidget-handle,
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled,
.oo-ui-textInputWidget .oo-ui-inputWidget-input,
.oo-ui-textInputWidget.oo-ui-widget-enabled .oo-ui-inputWidget-input[readonly]:not(.oo-ui-pendingElement-pending) {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-border-color);
}
.oo-ui-pendingElement-pending {
background-color: var(--wiki-content-background-color--secondary);
background-image: linear-gradient(135deg, var(--wiki-content-background-color) 25%, transparent 25%, transparent 50%, var(--wiki-content-background-color) 50%, var(--wiki-content-background-color) 75%, transparent 75%, transparent);
}
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled select {
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-border-color)
}
.view-dark .oo-ui-inputWidget-input.oo-ui-indicator-down {
background-image: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2212%22 height=%2212%22 viewBox=%220 0 12 12%22%3E%3Ctitle%3E down %3C/title%3E%3Cg fill=%22%23fff%22%3E%3Cpath d=%22M9.9 2.9 6 6.8 2.1 2.9 1 4l5 5 5-5z%22/%3E%3C/g%3E%3C/svg%3E");
}
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled select:hover {
color: var(--wiki-content-text-mix-color);
border-color: var(--wiki-accent-color);
}
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled select:active {
color: var(--wiki-content-dynamic-color);
border-color: var(--wiki-accent-color)
}
.oo-ui-dropdownInputWidget select option,
.oo-ui-dropdownInputWidget select optgroup {
color: #000;
}
.oo-ui-dropdownWidget.oo-ui-widget-enabled .oo-ui-dropdownWidget-handle:hover,
.oo-ui-dropdownWidget.oo-ui-widget-enabled .oo-ui-dropdownWidget-handle:focus,
.oo-ui-dropdownWidget.oo-ui-widget-enabled .oo-ui-dropdownWidget-handle:active,
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled:hover,
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled:focus,
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled:active,
.oo-ui-textInputWidget.oo-ui-widget-enabled:hover .oo-ui-inputWidget-input,
.oo-ui-textInputWidget.oo-ui-widget-enabled .oo-ui-inputWidget-input:focus,
.oo-ui-textInputWidget.oo-ui-widget-enabled:active .oo-ui-inputWidget-input,
.oo-ui-textInputWidget.oo-ui-widget-enabled:hover .oo-ui-inputWidget-input:focus {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border-color: var(--wiki-accent-color);
box-shadow: none;
}
.oo-ui-radioInputWidget [type="radio"] + span {
background-color: var(--wiki-content-dynamic-color--inverted);
}
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked + span,
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:hover + span {
border-color: color-mix(in srgb, var(--wiki-accent-color) 90%, transparent);
}
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked:hover + span {
border-color: var(--wiki-accent-color);
}
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:active + span,
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked:active + span {
background-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
border-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked:focus + span::before {
border-color: var(--wiki-content-dynamic-color--inverted);
}
.oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked:active + span {
border-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.oo-ui-menuOptionWidget.oo-ui-widget-enabled.oo-ui-optionWidget {
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-text-mix-color);
}
.oo-ui-menuOptionWidget.oo-ui-optionWidget.oo-ui-optionWidget-selected,
.oo-ui-menuOptionWidget.oo-ui-optionWidget.oo-ui-optionWidget-highlighted,
.oo-ui-menuOptionWidget.oo-ui-optionWidget.oo-ui-optionWidget-highlighted.oo-ui-optionWidget-selected,
.oo-ui-dropdownWidget.oo-ui-widget-enabled.oo-ui-dropdownWidget-open .oo-ui-dropdownWidget-handle {
background-color: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);
color: var(--wiki-content-text-color);
}
.oo-ui-menuOptionWidget.oo-ui-optionWidget-selected.oo-ui-menuOptionWidget.oo-ui-optionWidget-highlighted,
.oo-ui-menuOptionWidget.oo-ui-optionWidget-pressed.oo-ui-menuOptionWidget.oo-ui-optionWidget-highlighted {
background-color: color-mix(in srgb, var(--wiki-accent-color) 10%, transparent);
color: var(--wiki-accent-color);
}
.mw-prefs-tabs.mw-prefs-tabs-searching .oo-ui-tabPanelLayout.mw-prefs-search-matched > fieldset > legend {
background: var(--wiki-content-background-color--secondary);
}
.mw-prefs-search-highlight {
background-color: color-mix(in srgb, var(--wiki-accent-color) 7%, transparent) !important;
outline-color: color-mix(in srgb, var(--wiki-accent-color) 7%, transparent) !important;
}
/****************
* End preferences *
*****************/
/***************
* Page history *
****************/
#pagehistory li {
background-color: transparent;
border: none;
}
#pagehistory li.selected {
background-color: var(--wiki-content-background-color--secondary);
border: 1px dashed var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.diff td.diff-addedline {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-success-color);
border-width: 1px 1px 1px 4px;
}
.diff td.diff-addedline .diffchange {
background-color: var(--wiki-success-color);
color: var(--wiki-success-label-color);
}
.diff td.diff-deletedline {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-alert-color);
border-width: 1px 1px 1px 4px;
}
.diff td.diff-deletedline .diffchange {
background-color: var(--wiki-alert-color);
color: var(--wiki-alert-label-color)
}
.diff td.diff-context {
background: color-mix(in srgb, var(--wiki-content-text-mix-color-95) 80%, var(--wiki-content-background-color));
border-color: var(--wiki-neutral-color, var(--wiki-content-text-mix-color)); /* fallback for backwards compatibility */
color: var(--wiki-content-text-color);
}
.diff-marker a.mw-diff-movedpara-right {
color: transparent;
}
.diff-marker a.mw-diff-movedpara-right:hover:after {
opacity: .75;
}
.diff-marker a.mw-diff-movedpara-right:after {
color: var(--wiki-content-text-color);
content: "\21a9";
}
.diff-marker a.mw-diff-movedpara-left {
color: transparent;
}
.diff-marker a.mw-diff-movedpara-left:hover:after {
opacity: .75;
}
.diff-marker a.mw-diff-movedpara-left:after {
color: var(--wiki-content-text-color);
content: "\21aa";
}
.mw-plusminus-neg {
color: var(--wiki-alert-color);
}
.mw-plusminus-null {
color: var(--wiki-neutral-color, var(--wiki-content-text-mix-color)); /* fallback for backwards compatibility */
}
.mw-plusminus-pos {
color: var(--wiki-success-color);
}
.updatedmarker {
background-color: color-mix(in srgb, var(--wiki-success-color) 25%, transparent);
color: var(--wiki-content-text-color);
}
li span.deleted,
span.history-deleted {
color: var(--wiki-content-text-mix-color);
}
span.mw-history-suppressed {
/* overrides above, since suppressed is also deleted */
color: var(--wiki-content-text-color);
}
/* inline diff (1.41) */
.mw-diff-inline-header {
border-bottom: 1px solid var(--wiki-content-border-color);
}
.mw-diff-inline-added ins,
.mw-diff-inline-changed ins,
.mw-diff-inline-moved ins,
.mw-diff-table-prefix .mw-diff-inline-legend .mw-diff-inline-legend-ins,
.mw-diff-inline-added.mw-diff-empty-line::after,
.mw-inline-diff-newline::after {
background: color-mix(in srgb, var(--wiki-success-color) 90%, transparent);
color: var(--wiki-success-label-color);
display: inline-block;
}
.mw-diff-inline-added.mw-diff-empty-line::after,
.mw-diff-inline-deleted.mw-diff-empty-line::after,
.mw-inline-diff-newline::after {
padding: 0.4em 0;
}
.mw-diff-inline-deleted del,
.mw-diff-inline-changed del,
.mw-diff-inline-moved del,
.mw-diff-table-prefix .mw-diff-inline-legend .mw-diff-inline-legend-del,
.mw-diff-inline-deleted.mw-diff-empty-line::after {
background: color-mix(in srgb, var(--wiki-alert-color) 90%, transparent);
color: var(--wiki-alert-label-color);
display: inline-block;
}
.mw-diff-movedpara-left::after,
.mw-diff-movedpara-right::after {
color: var(--wiki-content-text-color);
}
.ve-ui-diffElement-hasDescriptions .ve-ui-diffElement-content {
border-right-color: var(--wiki-content-border-color);
}
.ve-ui-diffElement-attributeChange {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-diffElement-attributeChange ins {
background-color: color-mix(in srgb, var(--wiki-success-color) 90%, transparent);
box-shadow: 0 0 0 1px color-mix(in srgb, var(--wiki-success-color) 90%, transparent);
color: var(--wiki-success-label-color);
}
.ve-ui-diffElement-attributeChange del {
background-color: color-mix(in srgb, var(--wiki-alert-color) 90%, transparent);
box-shadow: 0 0 0 1px color-mix(in srgb, var(--wiki-alert-color) 90%, transparent);
color: var(--wiki-alert-label-color);
}
.ve-ui-diffElement-highlight {
outline-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.ve-ui-changeDescriptionsSelectWidget > .oo-ui-optionWidget-highlighted {
background: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);
}
/* Edit conflict */
.mw-twocolconflict-split-tour-image-dual-column-view-1 {
filter: var(--wiki-icon-general-filter);
}
.mw-twocolconflict-split-tour-image-blue-dot {
filter: brightness(0) var(--wiki-icon-to-link-filter);
}
.mw-pulsating-dot::before, .mw-pulsating-dot::after {
background-color: var(--wiki-content-link-color);
}
.mw-twocolconflict-split-current-version-header .mw-twocolconflict-revision-label {
background-color: var(--wiki-alert-color);
color: var(--wiki-alert-label-color);
}
.mw-twocolconflict-special-your-version-header .mw-twocolconflict-revision-label,
.mw-twocolconflict-split-your-version-header .mw-twocolconflict-revision-label {
background-color: var(--wiki-success-color);
color: var(--wiki-success-label-color);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-copy,
.mw-twocolconflict-split-column.mw-twocolconflict-split-copy {
border-color: var(--wiki-neutral-color, var(--wiki-content-text-mix-color)); /* fallback for backwards compatibility */
background-color: var(--wiki-content-text-mix-color-95);
}
.mw-twocolconflict-single-column .mw-twocolconflict-split-collapsed .mw-twocolconflict-split-fade,
.mw-twocolconflict-split-column .mw-twocolconflict-split-collapsed .mw-twocolconflict-split-fade {
background-image: linear-gradient(transparent, var(--wiki-content-text-mix-color-95));
}
.mw-twocolconflict-single-column,
.mw-twocolconflict-split-column {
background-color: var(--wiki-content-background-color);
color: var(--wiki-content-text-color);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-unselected,
.mw-twocolconflict-split-column.mw-twocolconflict-split-unselected {
color: color-mix(in srgb, var(--wiki-content-text-color) 80%, transparent);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-unselected.mw-twocolconflict-split-delete,
.mw-twocolconflict-split-column.mw-twocolconflict-split-unselected.mw-twocolconflict-split-delete {
border-color: color-mix(in srgb, var(--wiki-alert-color) 40%, transparent);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-delete,
.mw-twocolconflict-split-column.mw-twocolconflict-split-delete {
border-color: var(--wiki-alert-color);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-unselected.mw-twocolconflict-split-add,
.mw-twocolconflict-split-column.mw-twocolconflict-split-unselected.mw-twocolconflict-split-add {
border-color: color-mix(in srgb, var(--wiki-success-color) 40%, transparent);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-add,
.mw-twocolconflict-split-column.mw-twocolconflict-split-add {
border-color: var(--wiki-success-color);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-unselected del.mw-twocolconflict-diffchange,
.mw-twocolconflict-split-column.mw-twocolconflict-split-unselected del.mw-twocolconflict-diffchange {
background-color: color-mix(in srgb, var(--wiki-alert-color) 30%, transparent);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-unselected del.mw-twocolconflict-diffchange,
.mw-twocolconflict-split-column.mw-twocolconflict-split-unselected del.mw-twocolconflict-diffchange,
.mw-twocolconflict-single-column del.mw-twocolconflict-diffchange,
.mw-twocolconflict-split-column del.mw-twocolconflict-diffchange {
background-color: var(--wiki-alert-color);
color: var(--wiki-alert-label-color);
}
.mw-twocolconflict-single-column.mw-twocolconflict-split-unselected ins.mw-twocolconflict-diffchange,
.mw-twocolconflict-split-column.mw-twocolconflict-split-unselected ins.mw-twocolconflict-diffchange,
.mw-twocolconflict-single-column ins.mw-twocolconflict-diffchange,
.mw-twocolconflict-split-column ins.mw-twocolconflict-diffchange {
background-color: var(--wiki-success-color);
color: var(--wiki-success-label-color);
}
.mw-twocolconflict-split-selection > div:nth-child(2) .oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked + span,
.mw-twocolconflict-split-selection > div:nth-child(2) .oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:active + span,
.mw-twocolconflict-split-selection > div:nth-child(2) .oo-ui-radioInputWidget [type="radio"] + span {
border-color: color-mix(in srgb, var(--wiki-success-color) 80%, transparent);
background: color-mix(in srgb, var(--wiki-success-color) 10%, transparent);
}
.mw-twocolconflict-split-selection > div:nth-child(2) .oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:active + span,
.mw-twocolconflict-split-selection > div:nth-child(2) .oo-ui-radioInputWidget [type="radio"] + span {
border-color: color-mix(in srgb, var(--wiki-success-color) 90%, transparent);
background: color-mix(in srgb, var(--wiki-success-color) 10%, transparent);
}
.mw-twocolconflict-split-selection > div:nth-child(1) .oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:checked + span,
.mw-twocolconflict-split-selection > div:nth-child(1) .oo-ui-radioInputWidget.oo-ui-widget-enabled [type="radio"]:active + span,
.mw-twocolconflict-split-selection > div:nth-child(1) .oo-ui-radioInputWidget [type="radio"] + span {
border-color: color-mix(in srgb, var(--wiki-alert-color) 90%, transparent);
background: color-mix(in srgb, var(--wiki-alert-color) 10%, transparent);
}
.mw-twocolconflict-split-editable .mw-twocolconflict-split-editor {
color: var(--wiki-content-text-color);
}
/**/
/*******************
* End page history *
********************/
/********************
* Table of contents *
*********************/
#toc,
.toc,
.toccolours,
.mw-warning {
background: var(--wiki-content-toc-background, var(--wiki-content-background-color--secondary));
border-width: var(--wiki-content-toc-border-width, 1px);
border-style: var(--wiki-content-toc-border-style, solid);
border-color: var(--wiki-content-toc-border-color, var(--wiki-content-border-color));
border-radius: var(--wiki-content-toc-border-radius, 0px);
border-image: var(--wiki-content-toc-border-image, none);
box-shadow: var(--wiki-content-toc-box-shadow, none);
}
#mw-toc-heading {
border: 0;
}
.toctogglelabel {
color: var(--wiki-content-link-color);
}
.tocnumber {
color: var(--wiki-content-text-color);
}
/************************
* End table of contents *
*************************/
/*************
* Thumbnails *
**************/
img.thumbborder {
border: 1px solid var(--wiki-content-border-color);
padding: 5px;
}
div.thumbinner {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
li.gallerybox div.thumb {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
}
html .thumbimage {
background-color: unset;
border: 1px solid var(--wiki-content-border-color);
}
.thumb,
.thumb .thumbinner,
.thumb .thumbimage {
max-width: 100%;
box-sizing: border-box;
}
.thumb .thumbimage:not(audio) {
height: auto;
}
body.skin--responsive .mw-parser-output .thumb .thumbinner > .thumbcaption {
width: revert;
}
/* packed-overlay and packed-hover modes for galleries */
ul.mw-gallery-packed-hover li.gallerybox:hover div.gallerytextwrapper,
ul.mw-gallery-packed-overlay li.gallerybox div.gallerytextwrapper,
ul.mw-gallery-packed-hover li.gallerybox.mw-gallery-focused div.gallerytextwrapper {
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 65%, transparent);
}
/* for non-thumbnail left floaters, increased margin from 0.5em to account for <ul> */
div.floatleft,
table.floatleft {
margin-right: 1.4em;
}
/* Responsive floating thumbnails */
@media screen and (max-width: 720px) {
div.tright,
div.floatright,
div.tleft,
div.floatleft {
float: none;
margin: 0 auto;
width: fit-content;
}
}
/*****************
* End thumbnails *
******************/
/**************
* Wiki editor *
***************/
#wpTextbox0 {
/* need !important here to override inline styling */
background-color: var(--wiki-content-background-color) !important;
}
.wikiEditor-ui {
border: none;
}
.wikiEditor-ui .wikiEditor-ui-top,
.wikiEditor-ui .wikiEditor-ui-view {
border-color: var(--wiki-content-border-color);
}
.wikiEditor-ui-toolbar {
background: var(--wiki-content-background-color--secondary);
}
.wikiEditor-ui-toolbar .group,
.wikiEditor-ui-toolbar .section-secondary .group {
border-color: var(--wiki-content-border-color);
}
.wikiEditor-ui-toolbar .tabs span.tab a,
.wikiEditor-ui-toolbar .tabs span.tab a:visited,
.wikiEditor-ui-toolbar .tabs span.tab a.current,
.wiikiEditor-ui-toolbar .tabs span.tab a.current:visited,
.wikiEditor-ui-toolbar .booklet .index .current {
color: var(--wiki-content-link-color);
}
.wikiEditor-ui-toolbar .group .tool-select .options {
background: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
}
.wikiEditor-ui-toolbar .group .tool-select .options .option {
color: var(--wiki-content-text-color);
}
.wikiEditor-ui-toolbar .group .tool-select .menu .options .option:hover {
background-color: var(--wiki-content-background-color);
}
.wikiEditor-ui-toolbar .tabs span.tab a::before,
.wikiEditor-ui-toolbar .group .tool-select .label::after {
filter: var(--wiki-icon-general-filter);
}
.wikiEditor-ui-toolbar .group .label,
.wikiEditor-ui-toolbar .group .tool-select .label,
.wikiEditor-ui-toolbar .page-table th,
.wikiEditor-ui-toolbar .page-table td,
.wikiEditor-ui-toolbar .page-characters div span,
.wikiEditor-ui-toolbar .booklet .index div {
color: var(--wiki-content-text-color);
}
.wikiEditor-ui-toolbar .booklet > .index > :hover {
background-color: var(--wiki-content-background-color--secondary);
}
.wikiEditor-ui-toolbar .page-characters div span {
border: 1px solid var(--wiki-content-border-color);
}
.wikiEditor-ui-toolbar .sections .section,
.wikiEditor-ui-toolbar .booklet .pages,
.wikiEditor-ui-toolbar .booklet .index .current,
.wikiEditor-ui-toolbar .page-characters div span:hover {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 5%, transparent);
}
.wikiEditor-ui-toolbar .sections .section {
border-top: 1px solid var(--wiki-content-border-color);
}
.wikiEditor-ui-toolbar .page-characters div span:hover {
border-color: var(--wiki-content-border-color);
}
.wikiEditor-ui-toolbar .page-table td {
border-top: 1px solid var(--wiki-content-border-color);
}
.wikiEditor-ui-tabs div a {
background: #9A647F;
display: inline-block;
}
.wikiEditor-ui-tabs div.current {
border-bottom: 1px solid #3B3352;
}
.wikiEditor-ui-tabs div.current a {
font-weight: bold;
}
.wikiEditor-ui-tabs {
border-left: 1px solid #3B3352;
border-top: 1px solid #3B3352;
}
.wikiEditor-ui-text {
background-color: var(--wiki-content-dynamic-color--inverted);
}
.wikiEditor-preview-contents {
background: transparent;
background-color: rgba(255, 255, 255, 0.2);
border-color: #3B3352;
border-style: solid;
border-width: 0 1px 1px;
}
.wikiEditor-ui-controls {
background: transparent;
}
.wikiEditor-preview-contents,
.wikiEditor-preview-loading {
background-color: transparent;
}
.mw-wikiEditor-InsertLink-TitleInputField .oo-ui-messageWidget,
.mw-widget-titleWidget-menu .mw-widget-titleOptionWidget-description {
color: var(--wiki-content-text-mix-color);
}
.wikiEditor-toolbar-dialog {
max-width: 100%;
box-sizing: border-box;
}
.wikiEditor-toolbar-dialog .ui-dialog-content input[type='text']::placeholder {
color: var(--wiki-content-text-mix-color);
}
.ext-WikiEditor-ResizingDragBar {
background-color: var(--wiki-content-background-color--secondary);
}
.ext-WikiEditor-ResizingDragBar-ns {
border-color: var(--wiki-content-border-color);
}
.ext-WikiEditor-ResizingDragBar span {
background-color: var(--wiki-content-border-color);
}
.ext-WikiEditor-ResizingDragBar:hover span {
background-color: var(--wiki-content-text-mix-color);
}
.ext-WikiEditor-twopanes-TwoPaneLayout .ext-WikiEditor-twopanes-pane1,
.ext-WikiEditor-twopanes-TwoPaneLayout .ext-WikiEditor-twopanes-pane2 {
border-color: var(--wiki-content-border-color);
}
/* creates a warning message about previewing sidebar edits */
.page-MediaWiki_Sidebar .wikiEditor-ui-bottom:has(.ext-WikiEditor-twopanes-TwoPaneLayout)::before {
content:"Warning: Sidebar previews are not accurate. Please save to see your changes!";
background:var(--wiki-alert-color);
display:block;
text-align:center;
color:var(--wiki-alert-label-color);
}
.ext-WikiEditor-realtimepreview-button.oo-ui-toggleWidget-on .oo-ui-labelElement-label {
color: var(--wiki-accent-color);
}
.wikiEditor-ui-toolbar .group,
.wikiEditor-ui-toolbar .section-secondary .group {
border-color: var(--wiki-content-border-color);
}
.ext-WikiEditor-realtimepreview-button:hover {
background-color: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);
color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 3px var(--wiki-accent-color);
}
.ext-WikiEditor-realtimepreview-ErrorLayout {
background-color: var(--wiki-content-background-color);
}
.ext-WikiEditor-image-realtimepreview-error {
filter: var(--wiki-icon-general-filter);
}
.oo-ui-toggleButtonWidget.oo-ui-widget-enabled.oo-ui-buttonElement-frameless.oo-ui-toggleWidget-on .oo-ui-buttonElement-button {
background-color: var(--wiki-content-background-color--secondary);
}
.ext-WikiEditor-reloadButton.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button,
.ext-WikiEditor-reloadButton.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover {
background-color: var(--wiki-content-background-color);
}
.editOptions {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-border-color);
border-image: none;
border-radius: 0 0 5px 5px;
border-style: none solid solid;
border-width: medium 1px 1px;
}
input#wpSummary {
margin-bottom: 1em;
margin-top: 1em;
width: 80%;
}
.view-dark .ace_editor,
.ace_editor {
--ace-keywords: #CDA869;
--ace-regexp: #E9C062;
--ace-constants: #CF6A4C;
--ace-illegal: #F8F8F8;
--ace-deprecated: #D2A8A1;
--ace-support: #9B859D;
--ace-function: #DAD085;
--ace-list: #F9EE98;
--ace-variable: #7587A6;
--ace-string: #8F9D6A;
--ace-illegal-highlight: rgba(86, 45, 86, 0.75);
--ace-step-highlight: #665200;
--ace-multiselect-shadow: #141414;
}
.view-light .ace_editor {
--ace-keywords: #00f;
--ace-regexp: #036a07;
--ace-constants: #c5060b;
--ace-illegal: #f00;
--ace-deprecated: #f00;
--ace-support: #6d79de;
--ace-function: #3c4c72;
--ace-list: #b90690;
--ace-variable: #318495;
--ace-string: #036a07;
--ace-illegal-highlight: rgba(255, 0, 0, 0.1);
--ace-step-highlight: #fcff00;
--ace-multiselect-shadow: #fff;
}
.ace_editor .ace_gutter {
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 85%, transparent);
}
.ace_gutter-cell {
color: color-mix(in srgb, var(--wiki-content-dynamic-color) 40%, transparent);
}
.ace_editor .ace_print-margin {
width: 1px;
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 75%, transparent);
}
.ace_editor {
/* this image gradient hack effectively lets the element have 2 layers of background */
background-image: linear-gradient(var(--wiki-content-dynamic-color), var(--wiki-content-dynamic-color));
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 93%, transparent);
color: color-mix(in srgb, var(--wiki-content-dynamic-color) 93%, transparent);
}
.ace_editor .ace_cursor,
.ace-monokai .ace_punctuation,
.ace-monokai .ace_punctuation.ace_tag {
color: var(--wiki-content-text-color);
}
.ace_editor .ace_marker-layer .ace_selection {
background: color-mix(in srgb, var(--wiki-content-dynamic-color) 20%, transparent)
}
.ace_editor.ace_multiselect .ace_selection.ace_start {
box-shadow: 0 0 3px 0px var(--ace-multiselect-shadow);
}
.ace_editor .ace_marker-layer .ace_step {
background: var(--ace-step-highlight);
}
.ace_editor .ace_marker-layer .ace_active-line,
.ace_editor .ace_gutter-active-line {
background: color-mix(in srgb, var(--wiki-content-dynamic-color) 3.1%, transparent)
}
.ace-tm .ace_marker-layer .ace_selected-word {
background: color-mix(in srgb, var(--wiki-content-dynamic-color) 5%, transparent);
}
.ace_editor .ace_marker-layer .ace_selection {
background: color-mix(in srgb, var(--wiki-content-dynamic-color) 10%, transparent);
}
.ace_editor .ace_marker-layer .ace_selected-word {
border: 1px solid color-mix(in srgb, var(--wiki-content-dynamic-color) 20%, transparent);
}
.ace_editor .ace_invisible {
color: color-mix(in srgb, var(--wiki-content-dynamic-color) 25%, transparent);
}
.ace_editor .ace_keyword,
.ace_editor .ace_meta {
color: var(--ace-keywords);
}
.ace_editor .ace_constant,
.ace_editor .ace_constant.ace_numeric,
.ace_editor .ace_constant.ace_character,
.ace_editor .ace_constant.ace_character.ace_escape,
.ace_editor .ace_constant.ace_other,
.ace_editor .ace_heading,
.ace_editor .ace_markup.ace_heading,
.ace_editor .ace_support.ace_constant {
color: var(--ace-constants);
}
.ace_editor .ace_invalid.ace_illegal {
color: var(--ace-illegal);
background-color: var(--ace-illegal-highlight);
}
.ace_editor .ace_invalid.ace_deprecated {
text-decoration: underline;
font-style: italic;
color: var(--ace-deprecated);
}
.ace_editor .ace_support,
.ace_editor .ace_support.ace_type {
color: var(--ace-support);
}
.ace_editor .ace_fold {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 10%, transparent);
border-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 10%, transparent);
}
.ace_editor .ace_support.ace_function {
color: var(--ace-function);
}
.ace_editor .ace_list,
.ace_editor .ace_markup.ace_list,
.ace_editor .ace_storage {
color: var(--ace-list);
}
.ace_editor .ace_entity.ace_name.ace_function,
.ace_editor .ace_meta.ace_tag,
.ace_editor .ace_variable {
color: var(--ace-variable);
}
.ace_editor .ace_string {
color: var(--ace-string);
}
.ace_editor .ace_string.ace_regexp {
color: var(--ace-regexp);
}
.ace_editor .ace_comment {
font-style: italic;
color: color-mix(in srgb, var(--wiki-content-dynamic-color) 30%, transparent);
}
.ace_editor .ace_xml-pe {
color: color-mix(in srgb, var(--wiki-content-dynamic-color) 28%, transparent);
}
.ace_editor .ace_indent-guide {
background: none;
box-shadow: 1px 0 0 color-mix(in srgb, var(--wiki-content-dynamic-color) 20%, transparent);
}
.ace_search {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border: 1px solid var(--wiki-content-border-color);
}
.ace_search_field {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-mix-color);
}
.ace_button {
color: var(--wiki-content-text-color);
border: 1px solid var(--wiki-content-border-color);
}
.ace_button:hover {
background-color: var(--wiki-accent-color--hover);
color: var(--wiki-accent-label-color);
}
.ace_button.checked {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.ace_searchbtn {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
border: 1px solid var(--wiki-content-border-color);
}
.ace_searchbtn:hover {
background-color: var(--wiki-accent-color--hover);
color: var(--wiki-accent-label-color);
}
.ace_searchbtn.prev::after,
.ace_searchbtn.next::after {
border-color: var(--wiki-accent-label-color);
}
.ace_searchbtn_close {
filter: var(--wiki-icon-general-filter);
}
.wikiEditor-ui .codeEditor-status {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.mw-editform #wpTextbox1 {
background: color-mix(in srgb, var(--wiki-content-background-color) 50%, transparent);
color: var(--wiki-content-text-color);
}
.view-dark .ext-codemirror-wrapper,
.ext-codemirror-wrapper {
--codemirror-yellow: #ffd700;
--codemirror-light-blue: #adf;
--codemirror-blue: #08f;
--codemirror-green: #290;
--codemirror-red: #f50;
--codemirror-dark-red: #dd1616;
--codemirror-purple: #CD4EF9;
--codemirror-pink: #e0e;
--codemirror-light-gray: #eee;
--codemirror-gray: #84a0a0;
}
.view-light .ext-codemirror-wrapper {
--codemirror-yellow: #9e8500;
--codemirror-light-blue: #008ae7;
--codemirror-blue: #0085f9;
--codemirror-green: #290;
--codemirror-red: #ef4f00;
--codemirror-dark-red: #a11;
--codemirror-purple: #80c;
--codemirror-pink: #ed00ed;
--codemirror-light-gray: #858585;
--codemirror-gray: #6b8a8a;
}
.ext-codemirror-wrapper {
background-color: color-mix(in srgb, var(--wiki-content-background-color) 35%, transparent);
color: var(--wiki-content-text-color)
}
.cm-editor .cm-selectionBackground,
.cm-editor.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground {
background: color-mix(in srgb, var(--wiki-accent-color) 30%, transparent);
}
.cm-mw-keyword {
color: var(--codemirror-purple)
}
.cm-mw-def {
color: var(--codemirror-blue)
}
.cm-mw-variable-2 {
color: var(--codemirror-light-blue)
}
.cm-mw-string {
color: var(--codemirror-red)
}
.cm-mw-atom {
color: var(--codemirror-pink)
}
.cm-mw-number {
color: var(--codemirror-green)
}
.cm-mw-matching {
background-color: var(--codemirror-yellow)
}
.cm-mw-skipformatting {
background-color: var(--codemirror-light-blue)
}
.cm-mw-list {
color: var(--codemirror-blue)
}
.cm-mw-doubleUnderscore,
.cm-mw-hr,
.cm-mw-signature {
background-color: var(--wiki-content-background-color--secondary);
color: var(--codemirror-blue)
}
.cm-mw-indenting {
color: var(--codemirror-blue)
}
.cm-mw-mnemonic {
color: var(--codemirror-green)
}
.cm-mw-comment {
color: var(--codemirror-gray)
}
.cm-mw-apostrophes-bold,
.cm-mw-apostrophes-italic,
.cm-mw-section-header {
color: var(--codemirror-blue)
}
.cm-mw-template,
.cm-mw-template-argument-name,
.cm-mw-template-bracket,
.cm-mw-template-delimiter,
.cm-mw-template-name {
color: var(--codemirror-purple);
}
.cm-mw-templatevariable,
.cm-mw-templatevariable-bracket,
.cm-mw-templatevariable-delimiter,
.cm-mw-templatevariable-name {
color: var(--codemirror-red)
}
.cm-mw-parserfunction-bracket,
.cm-mw-parserfunction-delimiter,
.cm-mw-parserfunction-name {
color: var(--codemirror-dark-red)
}
.cm-mw-exttag-attribute,
.cm-mw-exttag-bracket,
.cm-mw-exttag-name,
.cm-mw-htmltag-attribute,
.cm-mw-htmltag-bracket,
.cm-mw-htmltag-name {
color: var(--codemirror-green)
}
.cm-mw-link,
.cm-mw-link-pagename {
color: var(--wiki-content-link-color)
}
.cm-mw-link-tosection {
color: var(--codemirror-blue)
}
.cm-mw-extlink,
.cm-mw-extlink-bracket,
.cm-mw-extlink-protocol,
.cm-mw-free-extlink,
.cm-mw-free-extlink-protocol,
.cm-mw-link-bracket,
.cm-mw-link-delimiter {
color: var(--wiki-content-link-color)
}
.cm-mw-table-bracket,
.cm-mw-table-definition,
.cm-mw-table-delimiter {
color: var(--codemirror-pink)
}
.cm-mw-matchingbracket {
background-color: var(--wiki-content-background-color--secondary);
box-shadow: inset 0 0 1px 1px var(--wiki-content-link-color);
font-weight: bold;
}
.cm-editor .cm-tooltip-autocomplete ul li[aria-selected] {
background: color-mix(in srgb, var(--wiki-content-link-color) 15%, var(--wiki-content-background-color));
color: var(--wiki-content-link-color);
}
/* VisualEditor: Fix broken toolbar layout */
.oo-ui-toolbar {
clear: none;
display: flex; /* fix overflow issue at narrow widths */
}
.ve-ui-toolbar > .oo-ui-toolbar-bar{
width: 100%; /* fix overflow issue at narrow widths */
}
.ve-ui-toolbar.ve-ui-toolbar-floating > .oo-ui-toolbar-bar{
width: auto; /* fix overflow issue at narrow widths */
}
.ve-init-mw-desktopArticleTarget-toolbar-open > .oo-ui-toolbar-bar > div:nth-child(4) {
display: none;
}
.ve-ui-toolbar-floating > .oo-ui-toolbar-bar {
top: var(--wikigg-header-scroll-height);
}
.oo-ui-toolbar-bar .oo-ui-toolbar-bar,
.ve-area-wrapper .oo-ui-toolbar-bar {
background-color: var(--wiki-content-background-color--secondary);
}
.ve-init-mw-desktopArticleTarget-originalContent .content-body {
clear: right;
}
/* fix a lot of empty space from TemplateData when using VE Source */
.tdg-editscreen-main.mw-body-content::after {
display: none;
}
/*************
* End editor *
**************/
/****************
* Tabber styles *
*****************/
.tabber__header {
box-shadow: inset 0 -1px 0 0 var(--wiki-content-border-color);
}
.tabber__tab,
.tabber__tab:visited {
color: var(--wiki-content-text-color);
}
.tabber__tab:hover,
.tabber__tab:hover:visited,
.tabber__tab[aria-selected="true"],
.tabber__tab[aria-selected="true"]:visited {
color: var(--wiki-content-link-color);
}
.tabber__tab[aria-selected="true"] {
box-shadow: 0 -2px 0 var(--wiki-content-link-color) inset;
}
.tabber__header__prev::after,
.tabber__header__next::after {
filter: var(--wiki-icon-general-filter);
}
/********************
* End Tabber styles *
*********************/
/***************************************
* Various fixes for multi-theme Vector *
****************************************/
:focus,
:focus-visible {
outline-color: var(--wiki-accent-color)
}
:focus-visible {
outline-style: solid;
}
.oo-ui-iconElement-icon {
filter: var(--wiki-icon-to-link-filter);
}
.oo-ui-iconElement-icon.oo-ui-icon-reload {
filter: brightness(0) var(--wiki-icon-to-link-filter);
}
fieldset {
border-color: var(--wiki-content-border-color);
}
hr {
background-color: var(--wiki-content-border-color);
}
.CategoryTreeToggle {
color: var(--wiki-content-link-color);
}
input,
select {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
input:hover,
input:focus,
input:active {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border-color: var(--wiki-accent-color);
box-shadow: none;
}
input:focus-visible {
outline: 1px solid var(--wiki-accent-color);
}
input::file-selector-button,
input[type="button"],
input[type="submit"] {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.vector-body blockquote {
border-color: var(--wiki-content-border-color);
}
/* category bar and filetoc */
.catlinks{
background: var(--wiki-content-catlinks-background, var(--wiki-content-background-color--secondary));
border-width: var(--wiki-content-catlinks-border-width, 1px);
border-style: var(--wiki-content-catlinks-border-style, solid);
border-color: var(--wiki-content-catlinks-border-color, var(--wiki-content-border-color));
border-radius: var(--wiki-content-catlinks-border-radius, 0px);
border-image: var(--wiki-content-catlinks-border-image, none);
box-shadow: var(--wiki-content-catlinks-box-shadow, none);
}
ul#filetoc {
background: var(--wiki-content-filetoc-background, var(--wiki-content-background-color--secondary));
border-width: var(--wiki-content-filetoc-border-width, 1px);
border-style: var(--wiki-content-filetoc-border-style, solid);
border-color: var(--wiki-content-filetoc-border-color, var(--wiki-content-border-color));
border-radius: var(--wiki-content-filetoc-border-radius, 0px);
border-image: var(--wiki-content-filetoc-border-image, none);
box-shadow: var(--wiki-content-filetoc-box-shadow, none);
}
/**/
body .ui-dialog .ui-widget-header {
/* we need an important here because the built-in styles have one :( */
background: var(--wiki-content-background-color) !important;
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.ui-widget-header .ui-dialog-titlebar-close .ui-icon-closethick {
filter: var(--wiki-icon-general-filter);
}
.ui-widget-header .ui-dialog-titlebar-close.ui-state-hover {
background: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
}
.ui-widget-content {
background: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border: 1px solid var(--wiki-content-border-color);
}
body .ui-button {
/* we need an important here because the built-in styles have one. Vector is a mess */
background: var(--wiki-accent-color) !important;
border-color: var(--wiki-accent-color) !important;
color: var(--wiki-accent-label-color);
}
body .ui-button:hover,
body .ui-button:focus,
body .ui-button:active {
/* we need an important here because we had to use some above */
background: var(--wiki-accent-color--hover) !important;
border-color: var(--wiki-accent-color--hover) !important;
color: var(--wiki-accent-label-color);
}
.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default {
color: var(--wiki-accent-label-color);
}
.ui-state-focus {
/* we need an important here because the built-in styles have one */
background: var(--wiki-accent-color) !important;
color: var(--wiki-accent-label-color) !important;
}
.ui-menu .ui-menu-item a {
color: var(--wiki-content-dynamic-color);
}
#contentSub,
#contentSub2 {
color: var(--wiki-content-text-mix-color);
}
/* notifications ("your edit was saved", etc.) */
.mw-notification {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-border-color);
top: var(--wikigg-header-scroll-height);
}
.mw-notification .oo-ui-labelElement-label {
color: var(--wiki-content-text-color);
}
.mw-notification .oo-ui-iconElement-icon {
filter: unset;
}
/**/
.mime-type.has-warning {
color: var(--wiki-content-text-color);
}
.oo-ui-image-warning.oo-ui-icon-alert,
.mw-ui-icon-alert-warning::before {
filter: drop-shadow(0 0 3px #000);
}
.oo-ui-image-invert.oo-ui-icon-subtract,
.mw-ui-icon-subtract-invert::before,
.oo-ui-image-invert.oo-ui-icon-add,
.mw-ui-icon-add-invert::before {
filter: brightness(0) var(--wiki-icon-to-link-filter);
filter: var(--wiki-icon-general-filter);
}
.mw_metadata td,
.mw_metadata th {
border-color: var(--wiki-content-border-color);
}
.mw_metadata th {
background-color: var(--wiki-content-background-color--secondary);
}
.mw_metadata td {
background-color: var(--wiki-content-background-color);
}
.mw-datatable td,
.mw-datatable th {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
}
#mw-allmessagestable tbody:hover td,
.mw-datatable tr:hover > td {
background-color: var(--wiki-content-background-color--secondary);
}
#mw-allmessagestable .am_default {
background-color: color-mix(in srgb, var(--wiki-accent-color) 80%, transparent);
color: var(--wiki-accent-label-color);
}
#mw-allmessagestable .am_actual,
#mw-allmessagestable tbody:hover .am_default {
background-color: color-mix(in srgb, var(--wiki-accent-color) 60%, transparent);
}
#mw-allmessagestable .am_actual {
color: var(--wiki-accent-label-color);
}
#mw-allmessagestable tbody:hover .am_actual {
background-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.mw-datatable,
.mw-json {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
color: inherit;
}
.mw-datatable > * > tr > th,
.mw-datatable > tr > th,
.mw-json > * > tr > th,
.mw-json > tr > th {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
padding-bottom: 9px;
padding-top: 9px;
}
.mw-datatable > * > tr > td,
.mw-datatable > tr > td,
.mw-json > * > tr > td,
.mw-json > tr > td {
border-color: var(--wiki-content-border-color);
}
.mw-json tr {
background-color: inherit;
}
.mw-json .mw-json-single-value,
.mw-json .mw-json-value,
.mw-json .value {
background: color-mix(in srgb, var(--wiki-success-color) 60%, transparent);
}
.mw-json .mw-json-empty {
background: var(--wiki-content-background-color--secondary);
}
.mw-message-box,
.mw-message-box-warning {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
}
.mw-message-box-warning {
border-color: var(--wiki-warning-color);
border-width: 1px 1px 1px 10px;
}
.mw-destfile-warning {
border-color: var(--wiki-warning-color);
color: var(--wiki-content-text-color);
background-color: color-mix(in srgb, var(--wiki-warning-color) 25%, transparent);
}
.wikitable *,
.wikitable :after,
.wikitable :before {
-webkit-box-sizing: inherit;
box-sizing: inherit;
}
.cargo-pagevalues-tableinfo {
background-color: var(--wiki-content-background-color);
border-bottom: 1px solid var(--wiki-content-border-color);
top: 46px;
position: static;
/* override sticky in the built-in */
}
.cargo-table-diagram .cargo-table-svg .node.entity-name rect {
fill: var(--wiki-content-background-color--secondary);
fill-opacity: 1;
}
.cargo-table-diagram .cargo-table-svg .node rect {
stroke: var(--wiki-content-border-color);
opacity: 1;
}
.cargo-table-diagram .cargo-table-svg .node text tspan {
fill: var(--wiki-content-text-color);
}
table.cargoTable {
color: var(--wiki-content-text-color);
}
table.cargoTable tbody td,
table.cargoTable thead th {
border: 1px solid var(--wiki-content-border-color);
}
table.cargoTable tr:hover {
background-color: color-mix(in srgb, var(--wiki-accent-color) 25%, transparent);
}
table.cargoTable thead tr:nth-child(odd),
table.cargoTable.noMerge thead tr:nth-child(odd) {
background-color: var(--wiki-accent-color);
}
table.cargoTable tbody tr:nth-child(2n),
table.cargoTable.noMerge tbody tr:nth-child(2n) {
background-color: var(--wiki-content-background-color);
}
table.cargoTable tbody tr:nth-child(odd),
table.cargoTable.noMerge tbody tr:nth-child(odd) {
background-color: var(--wiki-content-background-color--secondary);
}
table.cargoTable th.headerSort {
color: var(--wiki-accent-label-color);
}
table.cargoTable th.headerSort:hover {
color: var(--wiki-accent-label-color);
text-decoration: underline;
}
table.cargoTable th.headerSort::after {
background-color: var(--wiki-accent-link-color);
}
#mw-content-text div.cargoReplacementTableInfo {
background: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_processing,
.dataTables_wrapper .dataTables_paginate {
color: var(--wiki-content-text-color);
}
table.dataTable tbody tr {
background-color: var(--wiki-content-background-color);
}
table.dataTable.display tbody tr.odd > .sorting_1,
table.dataTable.order-column.stripe tbody tr.odd > .sorting_1 {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 75%, transparent);
}
table.dataTable.stripe tbody tr.odd,
table.dataTable.display tbody tr.odd,
table.dataTable.display tbody tr.even > .sorting_1,
table.dataTable.order-column.stripe tbody tr.even > .sorting_1 {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 50%, transparent);
}
table.dataTable.display tbody tr:hover > .sorting_1,
table.dataTable.order-column.hover tbody tr:hover > .sorting_1 {
background-color: color-mix(in srgb, var(--wiki-content-background-color) 75%, transparent);
}
table.dataTable.hover tbody tr:hover,
table.dataTable.display tbody tr:hover {
background-color: var(--wiki-content-background-color--secondary);
}
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:active {
/* we need this !important to override a built-in one */
color: var(--wiki-content-text-mix-color) !important;
}
table.dataTable.row-border tbody th,
table.dataTable.row-border tbody td,
table.dataTable.display tbody th,
table.dataTable.display tbody td {
border-top: 1px solid var(--wiki-content-border-color);
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
/* we need this !important to override a built-in one */
color: var(--wiki-content-text-mix-color) !important;
border: 1px solid var(--wiki-content-border-color);
background-color: var(--wiki-content-background-color);
background: linear-gradient(to bottom, var(--wiki-content-background-color) 0%, var(--wiki-content-background-color--secondary) 100%);
}
div.drilldown-filters-wrapper {
background-color: transparent;
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.action-pagevalues tr:nth-of-type(2n) {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 50%, transparent);
}
.action-pagevalues tr:hover {
background-image: linear-gradient(color-mix(in srgb, var(--wiki-accent-color) 20%, transparent), color-mix(in srgb, var(--wiki-accent-color) 20%, transparent));
}
div.specialCargoQuery-extraPane {
background: var(--wiki-content-background-color);
}
.oo-ui-panelLayout-framed {
border-color: var(--wiki-content-border-color);
}
.oo-ui-inputWidget-input + .oo-ui-image-invert.oo-ui-icon-check {
background-image: none;
}
.oo-ui-inputWidget-input:checked + .oo-ui-image-invert.oo-ui-icon-check::before {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
background-image: url(/load.php?modules=oojs-ui-core.icons&image=check&variant=invert&format=rasterized&skin=vector&version=y9f1k);
background-image: linear-gradient(transparent, transparent), url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2220%22 height=%2220%22 viewBox=%220 0 20 20%22%3E%3Ctitle%3E check %3C/title%3E%3Cg fill=%22%23fff%22%3E%3Cpath d=%22M7 14.2 2.8 10l-1.4 1.4L7 17 19 5l-1.4-1.4z%22/%3E%3C/g%3E%3C/svg%3E");
content: '';
pointer-events: none;
filter: var(--wiki-icon-general-filter);
}
.oo-ui-checkboxInputWidget [type="checkbox"] + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked + span {
filter: unset;
background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
border-color: color-mix(in srgb, var(--wiki-accent-color) 75%, transparent);
}
.oo-ui-checkboxInputWidget [type="checkbox"]:disabled + span {
background-color: var(--wiki-content-text-mix-color);
border-color: var(--wiki-content-text-mix-color);
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:hover + span {
border-color: var(--wiki-accent-color);
filter: unset;
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate + span {
background-color: var(--wiki-accent-color);
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked:focus + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate:focus + span {
box-shadow: none;
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:active + span {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:focus + span {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
outline: 1px solid transparent;
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked:focus + span {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:hover + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:active + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:focus + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked:hover + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked:active + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:checked:focus + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate:hover + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate:active + span,
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:indeterminate:focus + span {
background-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
border-color: var(--wiki-accent-color);
}
.oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type="checkbox"]:active + span {
background-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent)
}
.oo-ui-image-invert.oo-ui-icon-check {
background: none;
position: relative;
}
.oo-ui-inputWidget-input:checked + .oo-ui-image-invert.oo-ui-icon-check::before {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
background-image: url(/load.php?modules=oojs-ui-core.icons&image=check&variant=invert&format=rasterized&skin=vector&version=y9f1k);
background-image: linear-gradient(transparent, transparent), url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2220%22 height=%2220%22 viewBox=%220 0 20 20%22%3E%3Ctitle%3E check %3C/title%3E%3Cg fill=%22%23fff%22%3E%3Cpath d=%22M7 14.2 2.8 10l-1.4 1.4L7 17 19 5l-1.4-1.4z%22/%3E%3C/g%3E%3C/svg%3E");
content: '';
pointer-events: none;
filter: var(--wiki-icon-general-filter);
}
.oo-ui-indicatorElement-indicator {
filter: var(--wiki-icon-to-link-filter);
}
.oo-ui-tagItemWidget.oo-ui-widget-enabled:not(.oo-ui-tagItemWidget-fixed) {
background-color: var(--wiki-content-background-color--secondary);
}
.oo-ui-tagItemWidget.oo-ui-widget-enabled:hover {
color: var(--wiki-content-text-color--hover);
}
.oo-ui-tagItemWidget.oo-ui-widget-enabled:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-tagItemWidget.oo-ui-widget-disabled {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-mix-color);
border-color: var(--wiki-content-text-mix-color);
}
.client-js .mw-recentchanges-toplinks:not(.mw-recentchanges-toplinks-collapsed) {
border-color: var(--wiki-content-border-color);
}
.mw-rcfilters-ui-savedLinksListWidget-placeholder.oo-ui-optionWidget .oo-ui-labelElement-label {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-savedLinksListWidget-menu .mw-rcfilters-ui-savedLinksListItemWidget {
color: var(--wiki-content-text-color);
padding: 8px 6px;
-webkit-transition: color .3s, background-color .3s;
transition: color .3s, background-color .3s;
}
.mw-rcfilters-ui-savedLinksListWidget-menu .mw-rcfilters-ui-savedLinksListItemWidget:hover {
background-color: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);
color: var(--wiki-accent-color);
}
.mw-rcfilters-ui-savedLinksListItemWidget-label {
color: var(--wiki-accent-color);
}
.mw-rcfilters-ui-filterTagMultiselectWidget.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined {
background-color: transparent;
}
.mw-rcfilters-ui-filterTagMultiselectWidget.oo-ui-widget-enabled .oo-ui-tagMultiselectWidget-handle {
border-color: var(--wiki-content-border-color);
}
.mw-rcfilters-ui-filterTagMultiselectWidget.oo-ui-widget-enabled .oo-ui-tagMultiselectWidget-handle + .mw-rcfilters-ui-table,
.mw-rcfilters-ui-filterTagMultiselectWidget.oo-ui-widget-enabled .oo-ui-tagMultiselectWidget-handle.mw-rcfilters-ui-filterTagMultiselectWidget-emphasize {
background-color: var(--wiki-content-background-color--secondary);
}
.mw-rcfilters-ui-filterTagMultiselectWidget-views-select-widget.oo-ui-widget {
border-color: var(--wiki-content-border-color);
padding: 0;
}
.mw-rcfilters-ui-filterTagMultiselectWidget-wrapper-content-title {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-filterTagMultiselectWidget-wrapper-content-savedQueryTitle {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-filterTagMultiselectWidget-hideshowButton .oo-ui-buttonElement-button > .oo-ui-labelElement-label {
color: var(--wiki-content-link-color);
}
.mw-rcfilters-ui-filterTagMultiselectWidget-hideshowButton .oo-ui-buttonElement-button > .oo-ui-labelElement-label:hover {
color: var(--wiki-content-link-color--hover);
}
.mw-rcfilters-ui-filterTagMultiselectWidget-hideshowButton .oo-ui-buttonElement-button:before {
content: "[";
}
.mw-rcfilters-ui-filterTagMultiselectWidget-hideshowButton .oo-ui-buttonElement-button:after {
content: "]";
}
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button {
color: var(--wiki-content-text-color);
}
.oo-ui-tagItemWidget.oo-ui-widget-enabled .oo-ui-buttonElement-button:hover {
background-color: var(--wiki-content-dynamic-color--inverted);
}
.mw-rcfilters-ui-filterTagMultiselectWidget-emptyFilters {
color: color-mix(in srgb, var(--wiki-content-text-color) 60%, transparent);
}
.mw-rcfilters-ui-filterMenuSectionOptionWidget {
background-color: var(--wiki-content-background-color);
}
.oo-ui-menuSelectWidget {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-text-mix-color);
}
.mw-rcfilters-ui-filterMenuSectionOptionWidget-header-title.oo-ui-labelElement-label {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-filterMenuHeaderWidget-header {
background-color: var(--wiki-content-background-color);
border-bottom-color: var(--wiki-content-border-color);
}
.mw-rcfilters-ui-filterMenuHeaderWidget-title {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget:not(:last-child):not(.mw-rcfilters-ui-itemMenuOptionWidget-identifier-talk) {
border-bottom-color: var(--wiki-content-text-mix-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget-view-namespaces {
border-top-color: var(--wiki-content-border-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-optionWidget-selected,
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-optionWidget-selected .mw-rcfilters-ui-itemMenuOptionWidget-label-title,
.mw-rcfilters-ui-itemMenuOptionWidget:hover,
.mw-rcfilters-ui-itemMenuOptionWidget:hover .mw-rcfilters-ui-itemMenuOptionWidget-label-title {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-optionWidget-selected .oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type=checkbox] + span,
.mw-rcfilters-ui-itemMenuOptionWidget:hover .oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type=checkbox] + span {
border-color: var(--wiki-accent-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-optionWidget-selected,
.mw-rcfilters-ui-itemMenuOptionWidget:hover {
background-color: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent)
}
.mw-rcfilters-ui-itemMenuOptionWidget-excludeLabel,
.mw-rcfilters-ui-itemMenuOptionWidget-label-title {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget-label-desc {
color: color-mix(in srgb, var(--wiki-content-text-color) 60%, transparent);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted.oo-ui-optionWidget-selected:hover,
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted:not(.oo-ui-optionWidget-selected):hover {
background-color: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted.oo-ui-optionWidget-selected .mw-rcfilters-ui-itemMenuOptionWidget-label-title,
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted:not(.oo-ui-optionWidget-selected) .mw-rcfilters-ui-itemMenuOptionWidget-label-title {
color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted.oo-ui-optionWidget-selected .mw-rcfilters-ui-itemMenuOptionWidget-label-desc {
color: color-mix(in srgb, var(--wiki-content-text-color) 60%, transparent);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-optionWidget-selected .mw-rcfilters-ui-itemMenuOptionWidget-label-desc,
.mw-rcfilters-ui-itemMenuOptionWidget:hover .mw-rcfilters-ui-itemMenuOptionWidget-label-desc,
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted:not(.oo-ui-optionWidget-selected) .mw-rcfilters-ui-itemMenuOptionWidget-label-desc {
color: color-mix(in srgb, var(--wiki-content-text-color) 80%, transparent);
}
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted.oo-ui-optionWidget-selected .oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type=checkbox] + span,
.mw-rcfilters-ui-itemMenuOptionWidget.oo-ui-flaggedElement-muted:not(.oo-ui-optionWidget-selected) .oo-ui-checkboxInputWidget.oo-ui-widget-enabled [type=checkbox] + span {
border-color: var(--wiki-content-text-color);
}
.mw-rcfilters-ui-viewSwitchWidget label.oo-ui-labelWidget {
color: color-mix(in srgb, var(--wiki-content-text-color) 60%, transparent);
}
.oo-ui-tagItemWidget.oo-ui-widget-enabled,
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined .oo-ui-tagItemWidget.oo-ui-widget-enabled {
background-color: transparent;
color: var(--wiki-content-text-color);
border-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined .oo-ui-tagItemWidget.oo-ui-widget-enabled.selected {
background-color: color-mix(in srgb, var(--wiki-accent-color) 10%, transparent);
border-color: var(--wiki-accent-color);
}
.mw-rcfilters-ui-datePopupWidget {
border-color: var(--wiki-content-border-color);
}
.mw-rcfilters-ui-datePopupWidget .mw-rcfilters-ui-valuePickerWidget-title {
color: color-mix(in srgb, var(--wiki-content-text-color) 80%, transparent);
}
.mw-changeslist-legend,
.mw-rcfilters-ui-changesListWrapperWidget .mw-changeslist-legend {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
@keyframes fadeBlue {
60% {
border-top-color: var(--wiki-accent-color);
}
100% {
border-top-color: var(--wiki-content-border-color);
}
}
.mw-rcfilters-ui-changesListWrapperWidget-previousChangesIndicator {
border-top-color: var(--wiki-content-border-color);
}
.mw-rcfilters-ui-menuSelectWidget-footer {
background-color: var(--wiki-content-text-mix-color-95);
}
.mw-rcfilters-ui-filterMenuOptionWidget.oo-ui-flaggedElement-muted:not(.oo-ui-optionWidget-selected) {
background-color: color-mix(in srgb, var(--wiki-content-text-color) 10%, transparent);
}
.oo-ui-iconElement-icon.mw-rcfilters-ui-filterItemHighlightButton-circle {
filter: unset;
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined .mw-rcfilters-ui-tagItemWidget-selected.oo-ui-tagItemWidget.oo-ui-widget-enabled {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
border-color: var(--wiki-accent-color);
}
.mw-rcfilters-ui-tagItemWidget.oo-ui-flaggedElement-muted.oo-ui-tagItemWidget.oo-ui-widget-enabled .oo-ui-labelElement-label {
color: color-mix(in srgb, var(--wiki-content-text-color) 76%, transparent);
}
.mw-rcfilters-ui-tagItemWidget-popup-content {
color: color-mix(in srgb, var(--wiki-content-text-color) 75%, transparent);
}
/* fix for weird focus box on recentchanges arrows when clicking, but keep it for tab navigation */
.mw-enhancedchanges-checkbox:focus + * .mw-enhancedchanges-arrow {
outline: none;
}
.mw-enhancedchanges-checkbox:focus-visible + * .mw-enhancedchanges-arrow {
outline: 1px solid var(--wiki-accent-color);
}
/**/
.oo-ui-popupWidget-anchored-bottom .oo-ui-popupWidget-anchor:before {
border-top-color: var(--wiki-content-border-color);
}
.oo-ui-popupWidget-anchored-bottom .oo-ui-popupWidget-anchor:after {
border-top-color: var(--wiki-content-background-color--secondary);
}
.unpatrolled {
color: var(--wiki-alert-color);
}
.autocomment, .autocomment a, .autocomment a:visited {
color: var(--wiki-content-text-mix-color);
}
/* Recent changes filter highlighting */
.view-dark .mw-rcfilters-ui-changesListWrapperWidget li.mw-rcfilters-highlight-color-c1,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget .mw-rcfilters-highlight-color-c1 tr:first-child,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c1.mw-rcfilters-ui-highlights-enhanced-toplevel:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+2)),
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c1.mw-rcfilters-ui-highlights-enhanced-nested:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+4)) {
background-color: #1c283f;
}
.view-dark .mw-rcfilters-ui-changesListWrapperWidget li.mw-rcfilters-highlight-color-c2,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget .mw-rcfilters-highlight-color-c2 tr:first-child,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c2.mw-rcfilters-ui-highlights-enhanced-toplevel:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+2)),
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c2.mw-rcfilters-ui-highlights-enhanced-nested:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+4)) {
background-color: #0f3128;
}
.view-dark .mw-rcfilters-ui-changesListWrapperWidget li.mw-rcfilters-highlight-color-c3,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget .mw-rcfilters-highlight-color-c3 tr:first-child,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c3.mw-rcfilters-ui-highlights-enhanced-toplevel:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+2)),
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c3.mw-rcfilters-ui-highlights-enhanced-nested:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+4)) {
background-color: #352c10;
}
.view-dark .mw-rcfilters-ui-changesListWrapperWidget li.mw-rcfilters-highlight-color-c4,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget .mw-rcfilters-highlight-color-c4 tr:first-child,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c4.mw-rcfilters-ui-highlights-enhanced-toplevel:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+2)),
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c4.mw-rcfilters-ui-highlights-enhanced-nested:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+4)) {
background-color: #411d0c;
}
.view-dark .mw-rcfilters-ui-changesListWrapperWidget li.mw-rcfilters-highlight-color-c5,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget .mw-rcfilters-highlight-color-c5 tr:first-child,
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c5.mw-rcfilters-ui-highlights-enhanced-toplevel:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+2)),
.view-dark .mw-rcfilters-ui-changesListWrapperWidget tr.mw-rcfilters-highlight-color-c5.mw-rcfilters-ui-highlights-enhanced-nested:not(.mw-rcfilters-ui-changesListWrapperWidget-enhanced-grey) td:not(:nth-child(-n+4)) {
background-color: #3f0f0f;
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled,
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined {
background-color: transparent;
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled .oo-ui-tagMultiselectWidget-handle {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
-webkit-transition: border-color 300ms, box-shadow 300ms;
transition: border-color 300ms, box-shadow 300ms;
background-color: var(--wiki-content-background-color--secondary)
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-inlined.oo-ui-tagMultiselectWidget-focus .oo-ui-tagMultiselectWidget-handle {
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
outline: 0
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-inlined:hover .oo-ui-tagMultiselectWidget-handle {
border-color: var(--wiki-accent-color)
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-inlined.oo-ui-flaggedElement-invalid .oo-ui-tagMultiselectWidget-handle,
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-inlined.oo-ui-flaggedElement-invalid:hover .oo-ui-tagMultiselectWidget-handle {
border-color: var(--wiki-alert-color)
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined .oo-ui-tagMultiselectWidget-handle {
background-color: var(--wiki-content-background-color--secondary);
border-bottom-width: 0;
border-bottom-left-radius: 0;
border-bottom-right-radius: 0
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined .oo-ui-inputWidget-input {
border-radius: 0;
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-tagMultiselectWidget-outlined.oo-ui-flaggedElement-invalid .oo-ui-inputWidget-input {
border-color: var(--wiki-alert-color);
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-enabled.oo-ui-flaggedElement-invalid .oo-ui-inputWidget-input {
color: var(--wiki-alert-color);
}
.oo-ui-tagMultiselectWidget.oo-ui-widget-disabled .oo-ui-tagMultiselectWidget-handle {
opacity: 0.5;
}
.oo-ui-tagMultiselectWidget-handle .oo-ui-tagMultiselectWidget-group > input {
color: var(--wiki-content-text-color);
}
.oo-ui-tagMultiselectWidget .oo-ui-inputWidget-input {
color: inherit;
background: transparent;
font-family: inherit;
}
.oo-ui-dropdownWidget.oo-ui-widget-disabled .oo-ui-dropdownWidget-handle,
.oo-ui-textInputWidget.oo-ui-widget-disabled .oo-ui-inputWidget-input,
.oo-ui-dropdownWidget.oo-ui-widget-disabled .oo-ui-dropdownWidget-handle {
background: var(--wiki-content-text-mix-color-95);
color: color-mix(in srgb, var(--wiki-content-text-color) 25%, transparent);
text-shadow: none;
border-color: var(--wiki-content-text-mix-color);
}
.oo-ui-textInputWidget.oo-ui-widget-enabled .oo-ui-inputWidget-input::placeholder {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-dropdownInputWidget select {
border-color: var(--wiki-content-border-color);
}
.oo-ui-dropdownInputWidget.oo-ui-widget-enabled select:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-toggleSwitchWidget {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:hover {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 95%, var(--wiki-content-dynamic-color));
border-color: color-mix(in srgb, var(--wiki-content-border-color) 95%, var(--wiki-content-dynamic-color));
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled .oo-ui-toggleSwitchWidget-grip {
background-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
border-color: #0006;
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:hover .oo-ui-toggleSwitchWidget-grip {
background-color: color-mix(in srgb, var(--wiki-accent-color) 90%, var(--wiki-content-dynamic-color));
border-color: #0006;
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on .oo-ui-toggleSwitchWidget-grip {
background-color: var(--wiki-accent-label-color);
border-color: #0006;
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:focus .oo-ui-toggleSwitchWidget-grip {
border-color: var(--wiki-accent-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on:hover {
background-color: var(--wiki-accent-color--hover);
border-color: var(--wiki-accent-color--hover);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:active,
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:active:hover,
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:active:focus {
background-color: var(--wiki-accent-color--hover);
border-color: var(--wiki-accent-color--hover);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color--hover);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:active .oo-ui-toggleSwitchWidget-grip,
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:active:hover .oo-ui-toggleSwitchWidget-grip,
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:active:focus .oo-ui-toggleSwitchWidget-grip {
background-color: var(--wiki-accent-label-color);
border-color: var(--wiki-accent-label-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on:active,
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on:active:hover {
background-color: var(--wiki-accent-color--hover);
border-color: var(--wiki-accent-color--hover);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on:focus {
border-color: var(--wiki-accent-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-enabled.oo-ui-toggleWidget-on:focus::before {
border-color: var(--wiki-accent-label-color);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-disabled {
background-color: var(--wiki-content-text-mix-color-95);
border-color: var(--wiki-content-text-mix-color-95);
}
.oo-ui-toggleSwitchWidget.oo-ui-widget-disabled.oo-ui-toggleWidget-off .oo-ui-toggleSwitchWidget-grip {
border-color: var(--wiki-content-dynamic-color--inverted);
box-shadow: inset 0 0 0 1px var(--wiki-content-dynamic-color--inverted);
}
.oo-ui-outlineOptionWidget.oo-ui-optionWidget-selected,
.oo-ui-outlineOptionWidget.oo-ui-optionWidget-highlighted {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-link-color);
}
.oo-ui-labelWidget.oo-ui-inline-help {
color: color-mix(in srgb, var(--wiki-content-text-color) 80%, transparent);
}
.oo-ui-progressBarWidget:not(.oo-ui-pendingElement-pending) {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-accent-color);
box-shadow: 0 1px 1px color-mix(in srgb, var(--wiki-content-dynamic-color) 15%, transparent);
}
.oo-ui-progressBarWidget.oo-ui-widget-enabled .oo-ui-progressBarWidget-bar {
background-color: var(--wiki-accent-color);
}
.oo-ui-bookletLayout-outlinePanel {
padding: 7px 0;
}
.oo-ui-processDialog-content .oo-ui-window-head,
.oo-ui-processDialog-content .oo-ui-window-foot,
.oo-ui-messageDialog-content > .oo-ui-window-head,
.oo-ui-messageDialog-content > .oo-ui-window-foot {
outline-color: var(--wiki-content-border-color);
}
.oo-ui-messageDialog-actions-horizontal .oo-ui-actionWidget {
border-right-color: var(--wiki-content-border-color);
}
.oo-ui-messageDialog-title {
color: var(--wiki-content-heading-color);
}
.oo-ui-processDialog-actions-safe .oo-ui-widget-enabled.oo-ui-iconElement:not(.oo-ui-labelElement) > .oo-ui-buttonElement-button:hover {
background-color: var(--wiki-content-background-color);
border-right-color: var(--wiki-content-border-color);
}
.oo-ui-processDialog-errors {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 90%, transparent);
}
/* OAuth authorisation dialog */
#mw-mwoauth-authorize-form {
color: inherit;
}
.oo-ui-toolbar-bar,
.oo-ui-popupToolGroup-tools,
.oo-ui-listToolGroup-tools .oo-ui-tool.oo-ui-widget-enabled:hover {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
}
.oo-ui-popupToolGroup-tools {
max-width: 100%;
}
.oo-ui-toolbar-actions .oo-ui-popupToolGroup.oo-ui-widget-enabled > .oo-ui-popupToolGroup-handle:hover {
border-right-color: var(--wiki-content-border-color);
}
.oo-ui-menuToolGroup-tools .oo-ui-tool.oo-ui-tool-active,
.oo-ui-tool.oo-ui-widget-enabled > .oo-ui-tool-link:active,
.oo-ui-tool.oo-ui-widget-enabled.oo-ui-tool-active > .oo-ui-tool-link,
.oo-ui-tool.oo-ui-widget-enabled.oo-ui-popupToolGroup-active > .oo-ui-tool-link,
.oo-ui-popupToolGroup.oo-ui-popupToolGroup-active > .oo-ui-popupToolGroup-handle {
background-color: var(--wiki-content-background-color);
color: var(--wiki-content-link-color);
}
.oo-ui-tool.oo-ui-widget-enabled .oo-ui-tool-link {
/* we remove the transition here because it causes the hard-coded color to flash briefly */
transition: none;
}
.oo-ui-popupToolGroup.oo-ui-popupToolGroup-active > .oo-ui-popupToolGroup-handle:hover {
color: var(--wiki-accent-color);
}
.oo-ui-popupToolGroup-tools .oo-ui-tool-active.oo-ui-widget-enabled .oo-ui-tool-link .oo-ui-tool-title {
color: var(--wiki-accent-color);
}
.oo-ui-popupToolGroup.oo-ui-widget-enabled > .oo-ui-popupToolGroup-handle:hover,
.oo-ui-tool.oo-ui-widget-enabled > .oo-ui-tool-link:hover {
background-color: color-mix(in srgb, var(--wiki-accent-color) 10%, transparent);
}
.oo-ui-popupToolGroup.oo-ui-widget-enabled > .oo-ui-popupToolGroup-handle:active {
background-color: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);
}
.oo-ui-popupToolGroup-tools .oo-ui-tool.oo-ui-widget-enabled .oo-ui-tool-link:focus {
box-shadow: inset 0 0 0 2px var(--wiki-accent-color);
}
.oo-ui-popupToolGroup.oo-ui-widget-enabled > .oo-ui-popupToolGroup-handle:focus,
.oo-ui-tool.oo-ui-widget-enabled .oo-ui-tool-link:focus,
.oo-ui-tool.oo-ui-widget-enabled > .oo-ui-tool-link:focus {
outline: 1px solid var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-menuToolGroup,
.oo-ui-popupToolGroup-tools {
border-color: var(--wiki-content-border-color);
}
.oo-ui-toolbar-position-top > .oo-ui-toolbar-bar {
border-color: var(--wiki-content-border-color);
box-shadow: 0 1px 1px 0 color-mix(in srgb, var(--wiki-content-dynamic-color) 10%, transparent);
}
.oo-ui-barToolGroup-tools.oo-ui-toolGroup-enabled-tools .oo-ui-tool.oo-ui-widget-disabled.oo-ui-flaggedElement-primary > .oo-ui-tool-link,
.oo-ui-barToolGroup-tools.oo-ui-toolGroup-disabled-tools .oo-ui-tool.oo-ui-flaggedElement-primary > .oo-ui-tool-link {
background-color: var(--wiki-content-text-mix-color);
border-color: var(--wiki-content-text-mix-color);
}
.oo-ui-tool.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive > .oo-ui-tool-link {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.oo-ui-tool.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive > .oo-ui-tool-link:hover {
background-color: var(--wiki-accent-color--hover);
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-frameless > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled > .oo-ui-buttonElement-button {
color: var(--wiki-content-text-color);
}
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus {
color: var(--wiki-content-text-color--hover);
}
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-buttonElement-frameless.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button {
color: var(--wiki-content-text-color);
}
.oo-ui-buttonElement-frameless.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-frameless.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-frameless.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus {
color: var(--wiki-content-text-color--hover);
}
.oo-ui-buttonElement-frameless.oo-ui-flaggedElement-destructive > .oo-ui-buttonElement-button {
color: var(--wiki-alert-color);
}
.oo-ui-buttonElement-frameless > .oo-ui-buttonElement-button {
border: 1px solid transparent;
}
.oo-ui-buttonElement-frameless > button.oo-ui-buttonElement-button {
color: inherit;
}
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color), inset 0 0 0 2px var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus,
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active {
background-color: var(--wiki-accent-color--hover);
border-color: var(--wiki-accent-color--hover);
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive > .oo-ui-buttonElement-button {
background-color: #bf0017;
border-color: #bf0017;
color: #fff;
}
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus,
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-primary.oo-ui-flaggedElement-destructive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active {
background-color: #59000b;
border-color: #59000b;
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active > .oo-ui-buttonElement-button {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active > .oo-ui-buttonElement-button:focus {
box-shadow: inset 0 0 0 1px var(--wiki-accent-color--hover), inset 0 0 0 2px var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color--hover);
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-active.oo-ui-flaggedElement-progressive.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button:hover,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-buttonElement-pressed > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-buttonElement-active > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-popupToolGroup-active > .oo-ui-buttonElement-button {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-link-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-buttonElement-pressed > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-buttonElement-active > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-popupToolGroup-active > .oo-ui-buttonElement-button {
color: var(--wiki-accent-color);
}
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled.oo-ui-buttonElement-pressed > input.oo-ui-buttonElement-button,
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active {
background-color: color-mix(in srgb, var(--wiki-content-link-color) 8%, transparent);
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-text-mix-color);
}
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-frameless.oo-ui-widget-enabled.oo-ui-flaggedElement-progressive.oo-ui-buttonElement-pressed > .oo-ui-buttonElement-button {
color: color-mix(in srgb, var(--wiki-content-link-color) 90%, transparent);
border-color: color-mix(in srgb, var(--wiki-content-link-color) 90%, transparent);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover {
background-color: transparent;
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-flaggedElement-destructive > .oo-ui-buttonElement-button:hover {
background-color: var(--wiki-content-dynamic-color--inverted);
}
.oo-ui-buttonSelectWidget.oo-ui-widget-enabled:focus .oo-ui-buttonOptionWidget.oo-ui-optionWidget-selected .oo-ui-buttonElement-button {
border-color: var(--wiki-accent-color--hover);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color--hover), inset 0 0 0 2px var(--wiki-accent-label-color);
}
.mw-htmlform-ooui .mw-htmlform-matrix tbody tr:nth-child(2n) td,
.mw-htmlform-ooui .mw-htmlform-matrix tbody tr:hover td {
background-color: var(--wiki-content-background-color--secondary);
}
.oo-ui-popupWidget-popup {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.mw-advancedSearch-namespace-selection {
background: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
}
.oo-ui-popupWidget-popup .mw-advancedSearch-tooltip-head {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-menuSectionOptionWidget {
color: var(--wiki-content-text-mix-color);
}
/* possibly deprecated */
.mw-ui-button:not(:disabled) {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
color: var(--wiki-accent-color);
border-color: var(--wiki-content-border-color);
}
.mw-ui-button:not(:disabled):visited {
color: var(--wiki-accent-color);
}
.mw-ui-button:not(:disabled):hover {
background-color: var(--wiki-content-text-mix-color-95);
border-color: var(--wiki-content-border-color);
color: var(--wiki-accent-color--hover);
}
.mw-ui-button:not(:disabled):focus {
border-color: var(--wiki-accent-color);
color: var(--wiki-content-text-color);
box-shadow: none;
}
.mw-ui-button:not(:disabled):active,
.mw-ui-button:not(:disabled).is-on {
background-color: var(--wiki-content-background-color);
color: var(--wiki-content-dynamic-color);
border-color: var(--wiki-content-link-color);
}
/* end possibly deprecated */
.mw-ui-icon-before::before {
filter: var(--wiki-icon-to-link-filter);
}
.oo-ui-windowManager-modal > .oo-ui-dialog > .oo-ui-window-frame {
background-color: var(--wiki-content-background-color);
color: var(--wiki-content-text-color);
border-color: var(--wiki-content-border-color);
}
.oo-ui-windowManager-modal > .oo-ui-dialog {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 50%, transparent);
}
.oo-ui-windowManager-modal.oo-ui-windowManager-floating > .oo-ui-dialog > .oo-ui-window-frame {
border-color: var(--wiki-content-border-color);
}
.oo-ui-messageDialog-message {
color: var(--wiki-content-text-color);
}
.oo-ui-buttonElement-framed:not(.oo-ui-flaggedElement-primary):not(.oo-ui-buttonElement-active) > .oo-ui-buttonElement-button {
color: var(--wiki-content-text-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-disabled:not(.oo-ui-flaggedElement-primary):not(.oo-ui-buttonElement-active) > .oo-ui-buttonElement-button {
color: var(--wiki-content-text-mix-color-95);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button {
color: var(--wiki-accent-color);
border-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover {
color: var(--wiki-accent-color--hover);
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 3px var(--wiki-accent-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button:active,
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-buttonElement-pressed > .oo-ui-buttonElement-button {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-link-color--hover);
border-color: var(--wiki-content-link-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-disabled > .oo-ui-buttonElement-button,
.oo-ui-buttonElement-framed.oo-ui-widget-disabled.oo-ui-flaggedElement-primary > .oo-ui-buttonElement-button {
background-color: var(--wiki-content-text-mix-color);
border-color: var(--wiki-content-text-mix-color);
}
.tdg-templateDataParamWidget-param-description {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-messageWidget.oo-ui-flaggedElement-error:not(.oo-ui-messageWidget-block),
.mw-body-content .error {
color: var(--wiki-alert-color);
}
.oo-ui-messageWidget.oo-ui-messageWidget-block.oo-ui-flaggedElement-error {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-alert-color);
border-left-width: 10px;
}
.oo-ui-messageWidget.oo-ui-messageWidget-block.oo-ui-flaggedElement-warning {
background-color: var(--wiki-content-background-color--secondary);
}
.oo-ui-messageWidget.oo-ui-messageWidget-block.oo-ui-flaggedElement-success {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-success-color);
border-left-width: 10px;
}
.oo-ui-messageWidget.oo-ui-messageWidget-block.oo-ui-flaggedElement-notice {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-text-mix-color);
}
.tdg-templateDataParamWidget-param-alias {
color: var(--wiki-content-text-mix-color);
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
}
.tdg-templateDataParamWidget-param-alias:first-child {
background-color: var(--wiki-content-background-color--secondary);
}
.mw-templatedata-doc-muted {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-processDialog-actions-safe .oo-ui-widget-enabled.oo-ui-iconElement:not(.oo-ui-labelElement) > .oo-ui-buttonElement-button:active {
background-color: var(--wiki-content-background-color--secondary);
border-right-color: var(--wiki-accent-color);
}
/* Date picker */
.mw-widget-dateInputWidget-handle {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.mw-widget-dateInputWidget.oo-ui-widget-enabled .mw-widget-dateInputWidget-handle:hover {
border-color: var(--wiki-accent-color);
box-shadow: none;
}
.mw-widget-dateInputWidget.oo-ui-widget-enabled .mw-widget-dateInputWidget-handle:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.mw-widget-dateInputWidget.oo-ui-widget-enabled .mw-widget-dateInputWidget-handle > .oo-ui-labelElement-label {
color: var(--wiki-content-text-color);
}
.mw-widget-calendarWidget {
border-color: var(--wiki-content-border-color);
}
.mw-widget-calendarWidget:focus {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.mw-widget-dateInputWidget-calendar {
background-color: var(--wiki-content-background-color);
}
.mw-widget-dateInputWidget-calendar:focus {
box-shadow: inset 0 0 0 1px var(--wiki-accent-color), 0 2px 2px 0 rgba(0, 0, 0, 0.2);
}
.mw-widget-calendarWidget-header .oo-ui-labelElement-label,
.mw-widget-calendarWidget-day,
.mw-widget-calendarWidget-month,
.mw-widget-calendarWidget-year {
color: var(--wiki-content-text-color);
}
.mw-widget-calendarWidget-day-heading,
.mw-widget-calendarWidget-day-additional {
color: color-mix(in srgb, var(--wiki-content-text-color) 55%, transparent);
}
.mw-widget-calendarWidget-day-today {
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.mw-widget-calendarWidget-item-selected {
background-color: color-mix(in srgb, var(--wiki-accent-color) 90%, transparent);
color: var(--wiki-accent-label-color);
}
.mw-widget-calendarWidget-item:hover {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.mw-widgets-datetime-calendarWidget:focus {
border-color: var(--wiki-content-border-color);
box-shadow: none;
}
.mw-widgets-datetime-calendarWidget-grid {
overflow-x: initial;
}
.mw-widgets-datetime-dateTimeInputWidget-handle {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.mw-widgets-datetime-dateTimeInputWidget.oo-ui-widget-enabled .mw-widgets-datetime-dateTimeInputWidget-handle:hover {
border-color: var(--wiki-content-border-color);
}
.mw-widgets-datetime-dateTimeInputWidget.oo-ui-widget-enabled .mw-widgets-datetime-dateTimeInputWidget-editField:hover {
background-color: var(--wiki-content-background-color);
}
.mw-widgets-datetime-calendarWidget {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
}
.mw-widgets-datetime-calendarWidget-grid .mw-widgets-datetime-calendarWidget-cell.mw-widgets-datetime-calendarWidget-extra .oo-ui-buttonElement-button .oo-ui-labelElement-label {
color: color-mix(in srgb, var(--wiki-content-text-color) 55%, transparent);
}
/* Unpatrolled page creations on Special:NewPages */
.not-patrolled {
background-color: color-mix(in srgb, var(--wiki-warning-color) 16%, transparent);
}
.mw-spinner-container > div::after {
background-color: var(--wiki-content-text-color);
}
pre,
code,
.mw-code {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.mw-templatedata-doc-param-alias {
color: var(--wiki-content-text-mix-color);
}
.mw-highlight{
overflow: unset !important;
}
.mw-highlight pre{
overflow: auto;
}
div.mw-highlight,
.skin-theme-clientpref-night div.mw-highlight {
background-color: var(--wiki-content-dynamic-color--inverted);
margin: 0.5em 0;
}
.mw-highlight pre {
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 50%, transparent);
margin: 0;
}
.mw-content-ltr.mw-highlight-lines pre,
.mw-content-ltr.content .mw-highlight-lines pre {
padding-left: 3.5em;
box-shadow: inset 2.75em 0 0 var(--wiki-content-dynamic-color--inverted);
}
.mw-highlight .hll {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent)
}
.mw-apisandbox-toolbar {
background: var(--wiki-content-background-color--secondary);
top: var(--wikigg-header-scroll-height);
}
/* special:replacetext */
.ext-replacetext-searchoptions {
background-color: transparent;
border: 1px solid var(--wiki-content-border-color);
}
.ext-replacetext-searchoptions .ext-replacetext-divider {
border-bottom: 1px solid var(--wiki-content-border-color);
}
/**/
.view-dark textarea {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.view-dark textarea:focus-visible {
outline-color: var(--wiki-accent-color);
outline-style: solid;
}
.oo-ui-textInputWidget.oo-ui-widget-enabled textarea.oo-ui-inputWidget-input:focus {
outline: 1px solid var(--wiki-accent-color);
}
/* make math formulas legible on dark theme */
.mwe-math-fallback-image-inline,
.mwe-math-fallback-image-display,
.ve-ui-mwLatexPage-symbol {
filter: var(--wiki-icon-general-filter);
}
/* search bar */
#searchInput {
font-size: inherit; /* override UA style */
background-color: var(--wiki-navigation-search-background-color, var(--wiki-content-background-color--secondary));
background-image: var(--wiki-navigation-search-background-image, none);
background-position: var(--wiki-navigation-search-background-position, 0);
background-size: var(--wiki-navigation-search-background-size, auto);
background-repeat: var(--wiki-navigation-search-background-repeat, repeat);
border: var(--wiki-navigation-search-border-width, 1px) var(--wiki-navigation-search-border-style, solid) var(--wiki-navigation-search-border-color, var(--wiki-content-border-color));
border-radius: var(--wiki-navigation-search-border-radius, 2px);
color: var(--wiki-navigation-search-text-color, var(--wiki-content-text-color));
backdrop-filter: var(--wiki-navigation-search-backdrop-filter, none);
box-shadow: var(--wiki-navigation-search-box-shadow, none);
border-image: var(--wiki-navigation-search-border-image, none);
}
#searchInput:focus,
#searchform:hover #searchInput,
#searchform:hover #searchInput:focus {
border-color: var(--wiki-navigation-search-border-color--hover, var(--wiki-accent-color));
box-shadow: var(--wiki-navigation-search-box-shadow--hover, var(--wiki-navigation-search-box-shadow, none));
border-image: var(--wiki-navigation-search-border-image--hover, var(--wiki-navigation-search-border-image, none));
}
#searchButton {
filter: var(--wiki-icon-to-link-filter);
}
.vector-search-box-input::placeholder {
color: var(--wiki-content-text-mix-color);
}
/* Search suggestions */
.suggestions-results,
.suggestions-special {
background-color: var(--wiki-content-background-color--secondary);
}
.suggestions a.mw-searchSuggest-link,
.suggestions a.mw-searchSuggest-link:hover,
.suggestions a.mw-searchSuggest-link:active,
.suggestions a.mw-searchSuggest-link:focus {
color: var(--wiki-content-text-color);
}
.suggestions-result {
color: var(--wiki-content-link-color);
}
.suggestions-result-current {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.suggestions-special .special-label {
color: var(--wiki-content-text-mix-color);
}
.suggestions-special .special-query {
color: var(--wiki-content-text-color);
}
.suggestions-special.suggestions-result-current .special-label,
.suggestions-special.suggestions-result-current .special-query {
color: var(--wiki-accent-label-color);
}
/* search page */
fieldset#mw-searchoptions {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 50%, transparent);
border-color: var(--wiki-content-border-color);
}
#mw-searchoptions .divider {
border-color: var(--wiki-content-border-color);
}
.mw-search-profile-tabs {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 50%, transparent);
border: 1px solid var(--wiki-content-border-color);
margin-top: 1em;
}
.mw-search-profile-tabs div.search-types ul li.current a {
color: var(--wiki-content-text-color);
}
.results-info,
.mw-search-result-data {
color: var(--wiki-content-text-mix-color);
}
/**/
/* Login/register page */
.mw-number-text {
color: var(--wiki-content-text-mix-color);
}
.mw-body-content .mw-number-text h3 {
color: var(--wiki-content-heading-color);
}
.mw-number-text.icon-edits,
.mw-number-text.icon-pages,
.mw-number-text.icon-contributors {
position: relative;
background: none;
}
.mw-number-text.icon-edits::before,
.mw-number-text.icon-pages::before,
.mw-number-text.icon-contributors::before {
position: absolute;
width: 95px;
height: 100%;
left: 0;
top: 0;
content: '';
filter: brightness(0) var(--wiki-icon-general-filter);
}
.mw-number-text.icon-edits::before {
background: url() no-repeat left center;
}
.mw-number-text.icon-pages::before {
background: url() no-repeat left center
}
.mw-number-text.icon-contributors::before {
background: url() no-repeat left center
}
/**/
/* Multimedia viewer */
.mw-mmv-post-image,
.mw-mmv-image-metadata {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.mw-mmv-ttf-container .mw-mmv-ttf-ellipsis {
box-shadow: -4px 6px 0 0 var(--wiki-content-background-color);
}
.mw-mmv-title-para .mw-mmv-ttf-ellipsis {
background-color: var(--wiki-content-background-color);
}
.mw-mmv-title-para .mw-mmv-ttf-ellipsis::before {
background-image: linear-gradient(to right, transparent 0%, var(--wiki-content-background-color) 100%);
}
.mw-mmv-ttf-ellipsis-container:hover .mw-mmv-ttf-container .mw-mmv-ttf-ellipsis {
background-color: var(--wiki-content-background-color--secondary);
}
.mw-mmv-ttf-container .mw-mmv-ttf-ellipsis:hover, .mw-mmv-ttf-ellipsis-container .mw-mmv-ttf-container .mw-mmv-ttf-ellipsis:hover {
background-color: color-mix(in srgb, var(--wiki-content-background-color--secondary) 95%, var(--wiki-content-dynamic-color));
}
.mw-ui-button.mw-ui-progressive:not(:disabled) {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color);
}
.mw-ui-button.mw-ui-progressive:not(:disabled):hover {
background-color: var(--wiki-accent-color--hover);
}
.skin-vector .mw-ui-button.mw-ui-progressive:hover,
.skin-vector .mw-ui-button.mw-ui-primary:disabled {
box-shadow: 0px 0px 16px rgba(0, 0, 0, 0.75) inset, 0 0 5px var(--wiki-content-border-color);
border: 2px solid var(--wiki-content-border-color);
}
.mw-ui-button.mw-ui-progressive:not(:disabled):active,
.mw-ui-button.mw-ui-progressive:not(:disabled).is-on {
background-color: var(--wiki-accent-color);
border-color: var(--wiki-accent-color);
}
.mw-ui-button.mw-ui-progressive {
box-shadow: 0px 0px 16px rgba(0, 0, 0, 0.75) inset, 0 0 5px var(--wiki-content-border-color)
}
/* possibly deprecated */
.mw-ui-input:not(:disabled) {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.mw-ui-input:not(:disabled):hover,
.mw-ui-input:not(:disabled):focus {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
border-color: var(--wiki-accent-color);
box-shadow: none;
}
.mw-ui-input::placeholder {
color: var(--wiki-content-text-mix-color);
}
/* end possibly deprecated */
.mw-mmv-dialog {
background-color: var(--wiki-content-background-color);
box-shadow: 0 2px 2px 0 var(--wiki-content-border-color);
}
.mw-mmv-dialog .mw-mmv-dialog-down-arrow {
background-color: var(--wiki-content-background-color);
}
.mw-mmv-options-dialog-header {
color: var(--wiki-content-text-color);
}
.mw-mmv-options-text-header,
.mw-mmv-options-text-body {
color: var(--wiki-content-text-mix-color);
}
.mw-mmv-download-pane .mw-mmv-download-area .mw-mmv-download-select-menu {
background-image: none;
}
.mw-mmv-download-pane .mw-mmv-download-area .mw-mmv-download-select-menu span {
display: none;
}
.mw-mmv-download-pane .mw-mmv-download-area .mw-mmv-download-select-menu::after {
display: inline-block;
width: 8px;
height: 100%;
content: '';
--mask: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2212%22 height=%2212%22 viewBox=%220 0 12 12%22%3E %3Cpath fill=%22%23000%22 fill-rule=%22evenodd%22 d=%22m2.023 3 3.49 5.953L9 3z%22 clip-rule=%22evenodd%22/%3E %3C/svg%3E") no-repeat;
--mask-size: 12px;
--mask-position: center;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: var(--mask-size);
mask-size: var(--mask-size);
-webkit-mask-position: var(--mask-position);
mask-position: var(--mask-position);
background-color: currentColor;
}
.mw-mmv-embed-dimensions {
color: color-mix(in srgb, var(--wiki-content-text-color) 76%, transparent);
}
.oo-ui-optionWidget-selected .mw-mmv-embed-dimensions {
color: color-mix(in srgb, var(--wiki-content-text-color) 82%, transparent);
}
.mw-mmv-download-pane .mw-mmv-download-attribution {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-mix-color);
}
.mw-mmv-download-pane .mw-mmv-download-attribution:hover {
background-color: var(--wiki-content-dynamic-color--inverted);
color: var(--wiki-content-text-color);
}
.mw-mmv-download-pane .mw-mmv-download-area .mw-mmv-download-preview-link,
.mw-mmv-download-pane .mw-mmv-download-attribution-cta-invite {
color: var(--wiki-content-text-mix-color);
}
.mw-ui-button.mw-ui-quiet,
.mw-ui-button.mw-ui-quiet.mw-ui-progressive,
.mw-ui-button.mw-ui-quiet.mw-ui-destructive {
color: var(--wiki-accent-color);
}
.mw-ui-button.mw-ui-progressive:not(:disabled):focus {
box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 1), inset 0 0 0 2px var(--wiki-accent-color);
}
input[type="checkbox"]:active + .mw-ui-button.mw-ui-quiet,
input[type="checkbox"]:active + .mw-ui-button.mw-ui-quiet.mw-ui-progressive,
input[type="checkbox"]:active + .mw-ui-button.mw-ui-quiet.mw-ui-destructive,
.mw-ui-button.mw-ui-quiet:active,
.mw-ui-button.mw-ui-quiet.mw-ui-progressive:active,
.mw-ui-button.mw-ui-quiet.mw-ui-destructive:active,
input[type="checkbox"]:focus + .mw-ui-button.mw-ui-quiet,
input[type="checkbox"]:focus + .mw-ui-button.mw-ui-quiet.mw-ui-progressive,
input[type="checkbox"]:focus + .mw-ui-button.mw-ui-quiet.mw-ui-destructive,
.mw-ui-button.mw-ui-quiet:focus,
.mw-ui-button.mw-ui-quiet.mw-ui-progressive:focus,
.mw-ui-button.mw-ui-quiet.mw-ui-destructive:focus {
color: var(--wiki-content-text-color);
}
/**/
/* Echo */
.oo-ui-buttonElement-framed.oo-ui-widget-enabled.oo-ui-optionWidget-selected > .oo-ui-buttonElement-button:hover {
color: var(--wiki-accent-label-color);
}
.oo-ui-buttonElement-framed.oo-ui-widget-enabled > .oo-ui-buttonElement-button:hover {
color: var(--wiki-content-text-color);
}
@-webkit-keyframes unseen-fadeout-to-unread {
from {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
}
to {
background-color: var(--wiki-content-background-color--secondary);
}
}
@keyframes unseen-fadeout-to-unread {
from {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
}
to {
background-color: var(--wiki-content-background-color--secondary);
}
}
@-webkit-keyframes unseen-fadeout-to-read {
from {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
}
to {
background-color: var(--wiki-content-background-color);
}
}
@keyframes unseen-fadeout-to-read {
from {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
}
to {
background-color: var(--wiki-content-background-color);
}
}
.oo-ui-popupWidget-anchored-top .oo-ui-popupWidget-anchor:before {
border-bottom-color: var(--wiki-content-border-color);
}
.oo-ui-popupWidget-anchored-top .oo-ui-popupWidget-anchor:after {
border-bottom-color: var(--wiki-content-background-color--secondary);
}
.client-js .mw-echo-special-nojs {
filter: var(--wiki-icon-general-filter)
}
/**/
/* codex fixes */
.cdx-checkbox__icon {
background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
}
.mw-echo-ui-toggleReadCircleButtonWidget:hover .mw-echo-ui-toggleReadCircleButtonWidget-circle {
background-color: var(--wiki-accent-color--hover);
}
.mw-echo-ui-toggleReadCircleButtonWidget-circle-unread {
background-color: transparent;
}
.mw-echo-ui-toggleReadCircleButtonWidget:hover .mw-echo-ui-toggleReadCircleButtonWidget-circle-unread {
background-color: var(--wiki-content-text-mix-color-95);
}
/**/
/*************************
* End Vector theme fixes *
**************************/
/************************
* Theme-based Scribunto *
*************************/
#mw-scribunto-input {
background-color: var(--wiki-content-background-color--secondary);
border: 1px solid var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.mw-scribunto-console-fieldset,
.mw-scribunto-message,
.mw-scribunto-input,
.mw-scribunto-error,
.mw-scribunto-print,
.mw-scribunto-normalOutput {
background: transparent;
}
.mw-scribunto-console-fieldset {
color: var(--wiki-content-text-color);
}
.mw-scribunto-message {
color: var(--wiki-content-text-color);
}
.mw-scribunto-input {
color: var(--wiki-content-text-color--hover);
}
.mw-scribunto-error {
color: var(--wiki-alert-color);
}
.mw-scribunto-print {
color: var(--wiki-content-text-color);
}
.mw-scribunto-normalOutput {
color: var(--wiki-content-text-color);
}
/****************
* End Scribunto *
*****************/
/***************************
* Theme-based VisualEditor *
****************************/
.ve-activated .vector-menu-tabs .selected {
box-shadow: none;
}
.ve-init-mw-progressBarWidget {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-accent-color);
box-shadow: 0 1px 1px color-mix(in srgb, var(--wiki-content-dynamic-color) 15%, transparent);
}
.ve-init-mw-progressBarWidget-bar {
background-color: var(--wiki-accent-color);
}
.ve-init-mw-desktopArticleTarget-toolbarPlaceholder-bar {
border-bottom-color: var(--wiki-content-border-color);
}
.ve-init-mw-desktopArticleTarget-toolbarPlaceholder-floating .ve-init-mw-desktopArticleTarget-toolbarPlaceholder-bar {
top: var(--wikigg-header-scroll-height, 0);
background: var(--wiki-content-background-color);
}
div.ve-ce-branchNode {
border-color: var(--wiki-content-border-color);
}
.ve-ce-focusableNode-highlight {
background: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.ve-ce-surface-highlights-focused .ve-ce-focusableNode-highlights {
opacity: 0.25;
}
.ve-ce-branchNode-blockSlug, .ve-ce-branchNode-newSlug:not(.ve-ce-branchNode-newSlug-open) {
outline-color: var(--wiki-accent-color);
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 75%, transparent);
}
figure[typeof~='mw:File/Thumb'],
figure[typeof~='mw:File/Frame'],
figure[typeof~='mw:Image/Thumb'],
figure[typeof~='mw:Video/Thumb'],
figure[typeof~='mw:Audio/Thumb'],
figure[typeof~='mw:Image/Frame'],
figure[typeof~='mw:Video/Frame'],
figure[typeof~='mw:Audio/Frame'] {
border-color: var(--wiki-content-border-color);
background-color: var(--wiki-content-background-color--secondary);
}
figure[typeof~='mw:File/Thumb'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:File/Frame'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Image/Thumb'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Video/Thumb'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Audio/Thumb'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Image/Frame'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Video/Frame'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Audio/Frame'] > a:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:File/Thumb'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:File/Frame'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Image/Thumb'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Video/Thumb'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Audio/Thumb'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Image/Frame'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Video/Frame'] > span:first-child > *:first-child:not(.mw-broken-media),
figure[typeof~='mw:Audio/Frame'] > span:first-child > *:first-child:not(.mw-broken-media) {
border-color: var(--wiki-content-border-color);
background: var(--wiki-content-background-color--secondary);
}
figure[typeof~='mw:File/Thumb'] > figcaption,
figure[typeof~='mw:File/Frame'] > figcaption,
figure[typeof~='mw:Image/Thumb'] > figcaption,
figure[typeof~='mw:Video/Thumb'] > figcaption,
figure[typeof~='mw:Audio/Thumb'] > figcaption,
figure[typeof~='mw:Image/Frame'] > figcaption,
figure[typeof~='mw:Video/Frame'] > figcaption,
figure[typeof~='mw:Audio/Frame'] > figcaption {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.ve-ui-specialCharacterPage-character,
.oo-ui-toolbar-position-top .ve-ui-toolbarDialog-position-above,
.oo-ui-bookletLayout > .oo-ui-menuLayout-menu,
.ve-ui-mwTwoPaneTransclusionDialogLayout > .oo-ui-menuLayout-menu,
.ve-ui-specialCharacterPage-character:hover {
border-color: var(--wiki-content-border-color);
}
.ve-ui-specialCharacterPage-character:hover {
box-shadow: inset 0 0 1px 1px var(--wiki-accent-color);
}
.oo-ui-listToolGroup-tools .oo-ui-tool.oo-ui-widget-disabled .oo-ui-tool-title,
.oo-ui-popupToolGroup-tools .oo-ui-tool-link .oo-ui-tool-accel {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-barToolGroup-tools.oo-ui-toolGroup-enabled-tools .oo-ui-tool.oo-ui-widget-disabled.oo-ui-flaggedElement-primary > .oo-ui-tool-link .oo-ui-tool-title,
.oo-ui-barToolGroup-tools.oo-ui-toolGroup-disabled-tools .oo-ui-tool.oo-ui-flaggedElement-primary > .oo-ui-tool-link .oo-ui-tool-title {
color: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 78%, transparent);
}
.ve-activated .ve-init-mw-desktopArticleTarget-originalContent #catlinks:hover {
background: color-mix(in srgb, var(--wiki-content-link-color) 10%, transparent);
}
.oo-ui-tabSelectWidget-frameless .oo-ui-tabOptionWidget.oo-ui-optionWidget-selected {
color: var(--wiki-accent-color);
box-shadow: inset 0 -2px 0 0 var(--wiki-accent-color);
}
.oo-ui-tabOptionWidget {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-tabSelectWidget-frameless .oo-ui-tabOptionWidget.oo-ui-widget-enabled:not(.oo-ui-optionWidget-selected):hover {
color: var(--wiki-accent-color--hover);
box-shadow: inset 0 -2px 0 0 var(--wiki-accent-color--hover);
}
.oo-ui-tabSelectWidget-frameless .oo-ui-tabOptionWidget.oo-ui-widget-enabled:not(.oo-ui-optionWidget-selected):active {
color: var(--wiki-content-text-color);
box-shadow: inset 0 -2px 0 0 var(--wiki-accent-color--hover);
}
.oo-ui-tabSelectWidget-frameless {
box-shadow: inset 0 -1px 0 0 var(--wiki-content-border-color);
}
.oo-ui-textInputWidget.oo-ui-widget-enabled.oo-ui-flaggedElement-invalid .oo-ui-inputWidget-input {
border-color: var(--wiki-alert-color);
}
.ve-ce-linkAnnotation.ve-ce-annotation-active {
box-shadow: 0 0 0 1px color-mix(in srgb, var(--wiki-content-link-color) 20%, transparent);
background-color: color-mix(in srgb, var(--wiki-content-link-color) 10%, transparent);
}
.ve-ui-mwInternalLinkContextItem-withImage > .oo-ui-iconElement.oo-ui-iconElement-icon {
background-color: color-mix(in srgb, var(--wiki-content-text-mix-color-95) 90%, var(--wiki-content-dynamic-color));
border-color: color-mix(in srgb, var(--wiki-content-text-mix-color-95) 90%, var(--wiki-content-dynamic-color));
filter: unset;
}
.mw-widget-titleWidget-menu-withImages .mw-widget-titleOptionWidget.oo-ui-iconElement > .oo-ui-iconElement-icon.mw-widget-titleOptionWidget-hasImage {
filter: unset;
}
.mw-widget-titleWidget-menu-withImages .mw-widget-titleOptionWidget.oo-ui-iconElement > .oo-ui-iconElement-icon:not(.mw-widget-titleOptionWidget-hasImage) {
background-color: color-mix(in srgb, var(--wiki-content-text-mix-color-95) 90%, var(--wiki-content-dynamic-color));
filter: unset;
}
.ve-ui-desktopContext .ve-ui-linkContextItem .ve-ui-linkContextItem-label .ve-ui-linkContextItem-label-preview {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-toolbarDialog {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 5%, transparent);
}
.ve-ce-languageAnnotation {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 20%, transparent);
border-color: var(--wiki-content-link-color);
}
.mw-widget-mediaResultWidget-overlay {
box-shadow: inset 0 0 0 1px var(--wiki-content-border-color);
}
.mw-widget-mediaResultWidget .mw-widget-mediaResultWidget-nameLabel {
color: #fff;
}
.oo-ui-processDialog-actions-safe .oo-ui-widget-enabled.oo-ui-iconElement:not(.oo-ui-labelElement) > .oo-ui-buttonElement-button {
background-color: transparent;
border-right-color: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
}
.oo-ui-selectFileWidget-dropTarget {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
}
.oo-ui-selectFileWidget.oo-ui-widget-enabled.oo-ui-selectFileWidget-dropTarget {
background-color: var(--wiki-content-background-color);
}
.oo-ui-selectFileWidget.oo-ui-widget-enabled.oo-ui-selectFileWidget-dropTarget:hover {
border-color: var(--wiki-content-text-mix-color);
}
.oo-ui-selectFileWidget.oo-ui-widget-enabled.oo-ui-selectFileWidget-canDrop.oo-ui-selectFileWidget-dropTarget,
.oo-ui-selectFileWidget.oo-ui-widget-enabled.oo-ui-selectFileWidget-canDrop .oo-ui-selectFileInputWidget-info > .oo-ui-inputWidget-input {
background-color: color-mix(in srgb, var(--wiki-accent-color) 10%, transparent);
color: var(--wiki-accent-color);
}
.oo-ui-selectFileWidget.oo-ui-widget-disabled.oo-ui-selectFileWidget-dropTarget,
.oo-ui-selectFileWidget.oo-ui-selectFileInputWidget-empty.oo-ui-widget-disabled.oo-ui-selectFileWidget-dropTarget {
background-color: var(--wiki-content-text-mix-color-95);
border-color: var(--wiki-content-dynamic-color--secondary);
}
.mw-upload-bookletLayout-filePreview {
background-color: var(--wiki-content-background-color--secondary);
}
.ve-ui-mwMediaDialog-panel-imageinfo-details {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-textInputWidget.oo-ui-widget-disabled .oo-ui-inputWidget-input {
-webkit-text-fill-color: color-mix(in srgb, var(--wiki-content-text-color) 50%, transparent);
}
.oo-ui-optionWidget.oo-ui-widget-disabled {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-mwLanguagesPage-languages-table th,
.ve-ui-mwLanguagesPage-languages-table td {
border-bottom-color: var(--wiki-content-border-color);
}
.ve-ui-mwLanguagesPage-languages-table tr:nth-child(even) td {
background: var(--wiki-content-background-color);
}
.ve-ui-mwLanguagesPage-languages-table tr:nth-child(odd) td {
background: color-mix(in srgb, var(--wiki-content-dynamic-color--secondary) 5%, transparent);
}
.ve-ui-targetWidget {
border-color: var(--wiki-content-border-color);
}
.ve-ui-targetWidget:not(.oo-ui-pendingElement-pending) {
background: var(--wiki-content-background-color);
}
.ve-ui-targetWidget-focused {
border-color: var(--wiki-accent-color);
box-shadow: inset 0 0 0 1px var(--wiki-accent-color);
}
.ve-ui-mwTransclusionOutlineTemplateWidget-sticky {
background-color: var(--wiki-content-background-color);
}
.ve-ui-mwTransclusionOutlineTemplateWidget .ve-ui-mwTransclusionOutlineParameterWidget.oo-ui-optionWidget-highlighted {
color: var(--wiki-content-dynamic-color);
}
.ve-ui-mwTransclusionOutlineTemplateWidget .ve-ui-mwTransclusionOutlineParameterWidget.ve-ui-mwTransclusionOutlineParameterWidget-activePage,
.ve-ui-mwTransclusionOutlineTemplateWidget .ve-ui-mwTransclusionOutlineParameterWidget.ve-ui-mwTransclusionOutlineParameterWidget-activePage:hover,
.ve-ui-mwTransclusionOutlineTemplateWidget .ve-ui-mwTransclusionOutlineParameterWidget.ve-ui-mwTransclusionOutlineParameterWidget-activePage.oo-ui-optionWidget-highlighted {
color: var(--wiki-accent-color);
}
.ve-ui-mwTransclusionOutlineTemplateWidget-no-template-parameters {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-mwTemplatePage-description {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-mwParameterPage-doc-required,
.ve-ui-mwParameterPage-doc-deprecated,
.ve-ui-mwParameterPage-inlineDescription .ve-ui-mwParameterPage-doc-example {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-expandableContent-fade {
background: linear-gradient(to right, transparent 0, var(--wiki-content-background-color) 90%);
}
.ve-ui-expandableContent-toggle {
background-color: var(--wiki-content-background-color);
}
.ve-ui-mwParameterPage-undocumentedLabel {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-fieldLayout-disabled > .oo-ui-fieldLayout-body > .oo-ui-fieldLayout-header > .oo-ui-labelElement-label {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-mwLatexDialog-content .oo-ui-bookletLayout-stackLayout h3 {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-mwLatexPage-symbol {
border-color: var(--wiki-content-border-color);
}
.ve-ui-mwGalleryDialog-highlighted-image {
background-color: var(--wiki-content-background-color--secondary);
}
.ve-ui-mwHelpListToolGroup-tools-footer {
border-color: var(--wiki-content-border-color);
}
.ve-ui-mwHelpListToolGroup-version-link,
.ve-ui-mwHelpListToolGroup-version-date,
.ve-ui-mwHelpPopupTool-version-label,
.ve-ui-mwHelpPopupTool-version-link,
.ve-ui-mwHelpPopupTool-version-date {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-mwSaveDialog-summary {
background-color: var(--wiki-content-background-color);
}
.ve-ui-mwSaveDialog-options {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.ve-ui-mwSaveDialog-license {
color: var(--wiki-content-text-mix-color);
}
.oo-ui-processDialog .oo-ui-actionWidget:not(.oo-ui-flaggedElement-progressive):not(.oo-ui-flaggedElement-destructive) > .oo-ui-buttonElement-button:hover,
.oo-ui-processDialog .oo-ui-actionWidget:not(.oo-ui-flaggedElement-progressive):not(.oo-ui-flaggedElement-destructive) > .oo-ui-buttonElement-button:active {
border-right-color: var(--wiki-accent-color);
border-left-color: var(--wiki-accent-color);
}
.ve-ui-debugBar {
border-color: var(--wiki-content-border-color);
}
.ve-ui-debugBar-commands-divider {
border-color: var(--wiki-content-border-color);
}
.ve-ui-debugBar-dump > table {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.ve-ui-debugBar-dump td {
background-color: var(--wiki-content-background-color);
}
.ve-ui-debugBar-dump th {
color: color-mix(in srgb, var(--wiki-content-text-color) 80%, transparent);
text-shadow: 0 1px 1px var(--wiki-content-dynamic-color--inverted);
}
.ve-ui-debugBar-dump ol {
color: color-mix(in srgb, var(--wiki-content-text-color) 60%, transparent);
}
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-element,
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-char,
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-achar {
background-color: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-dynamic-color);
text-shadow: 0 1px 1px var(--wiki-content-dynamic-color--inverted);
}
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-element {
background-color: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
}
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-char {
background-color: color-mix(in srgb, var(--wiki-success-color) 20%, transparent);
}
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-achar {
background-color: color-mix(in srgb, var(--wiki-warning-color) 20%, transparent);
}
.ve-ui-debugBar-dump li .ve-ui-debugBar-dump-note {
color: var(--wiki-content-text-mix-color);
}
.ve-ui-debugBar-filibuster {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.ve-ui-debugBar-transactions > ol > li {
border-color: var(--wiki-content-border-color);
}
/*******************
* End VisualEditor *
********************/
/**************************
* Theme-based AbuseFilter *
***************************/
table.mw-abuselog-details {
background: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
}
table.mw-abuselog-details th,
table.mw-abuselog-details td,
div.mw-abusefilter-editor {
border-color: var(--wiki-content-border-color);
}
table.mw-abuselog-details th {
background: var(--wiki-content-background-color--secondary);
}
body td.mw-abusefilter-history-changed {
background-color: color-mix(in srgb, var(--wiki-alert-color) 20%, transparent);
}
/******************
* End AbuseFilter *
*******************/
/************************************
* Theme-based Special:MultiPageEdit *
*************************************/
:root {
--jexcel-border-color: var(--wiki-content-border-color); /* this is defined by the extension but does not seem to be used anywhere. We override it just in case *shrug* */
}
.jexcel,
.jexcel_container.fullscreen .jexcel_content {
background-color: var(--wiki-content-background-color);
border-bottom-color: var(--wiki-content-border-color);
border-right-color: var(--wiki-content-border-color);
}
table.jexcel > tbody > tr > td:first-child,
table.jexcel > thead,
table.jexcel > thead > tr > td,
table.jexcel > tbody > tr.selected > td:first-child,
table.jexcel > thead > tr > td.selected {
background-color: var(--wiki-content-background-color--secondary);
}
table.jexcel > tbody > tr.selected > td:first-child,
table.jexcel > thead > tr > td.selected {
background-color: color-mix(in srgb, var(--wiki-accent-color) 10%, transparent);
}
table.jexcel > thead > tr > td {
border-bottom-color: var(--wiki-content-border-color);
}
.jexcel > thead > tr > td.arrow-up,
.jexcel > thead > tr > td.arrow-down {
background: none;
}
.jexcel > thead > tr > td.arrow-up::after,
.jexcel > thead > tr > td.arrow-down::after {
display: inline-block;
position: absolute;
right: 0;
top: 0;
background-repeat: no-repeat;
background-position: center right 5px;
width: 22px;
height: 100%;
content: '';
filter: brightness(50%) var(--wiki-icon-general-filter);
}
.jexcel > thead > tr > td.arrow-up::after {
background-image: url("data:image/svg+xml,%0A%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='none' d='M0 0h24v24H0V0z'/%3E%3Cpath d='M7 14l5-5 5 5H7z' fill='gray'/%3E%3C/svg%3E");
}
.jexcel > thead > tr > td.arrow-down::after {
background-image: url("data:image/svg+xml,%0A%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='none' d='M0 0h24v24H0V0z'/%3E%3Cpath d='M7 10l5 5 5-5H7z' fill='gray'/%3E%3C/svg%3E");
}
.jexcel > thead > tr:nth-child(2) > td {
z-index: 1; /* prevents overlapping the headings after scrolling on tall tables */
}
.jexcel > tbody > tr > td {
border-top-color: var(--wiki-content-text-mix-color-95);
border-bottom-color: var(--wiki-content-text-mix-color-95);
}
.jexcel > tbody > tr > td.readonly {
color: var(--wiki-content-text-mix-color);
}
.jexcel_content {
scrollbar-color: var(--wiki-content-text-mix-color) transparent;
/* we need this important to override inline styling */
box-shadow: var(--wiki-content-dynamic-color--secondary--inverted) 2px 2px 5px 0.1px !important;
}
.jexcel .highlight {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 5%, transparent);
}
.jexcel .highlight-top {
border-top-color: var(--wiki-content-text-mix-color);
box-shadow: 0px -1px var(--wiki-content-dynamic-color--secondary--inverted);
}
.jexcel .highlight-left {
border-left-color: var(--wiki-content-text-mix-color);
box-shadow: -1px 0px var(--wiki-content-dynamic-color--secondary--inverted);
}
.jexcel .highlight-top.highlight-left {
box-shadow: -1px -1px var(--wiki-content-dynamic-color--secondary--inverted);
}
.jexcel .highlight-right {
border-right-color: var(--wiki-content-text-mix-color);
}
.jexcel .highlight-bottom {
border-bottom-color: var(--wiki-content-text-mix-color);
}
.jexcel .jexcel_column_filter {
background: none;
}
.jexcel .jexcel_column_filter::after {
display: inline-block;
position: absolute;
right: 0;
top: 0;
background-repeat: no-repeat;
background-position: top 50% right 5px;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='gray' width='18px' height='18px'%3E%3Cpath d='M10 18h4v-2h-4v2zM3 6v2h18V6H3zm3 7h12v-2H6v2z'/%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3C/svg%3E");
width: 20px;
height: 100%;
content: '';
filter: brightness(50%) var(--wiki-icon-general-filter);
}
.jexcel_pagination > div > div {
background-color: var(--wiki-accent-color);
/* we need this important to override a built-in one */
color: var(--wiki-accent-label-color) !important;
}
.jexcel_page_selected {
background: linear-gradient(to bottom, var(--wiki-accent-color) 0%, var(--wiki-accent-color--hover) 100%);
/* we need this important to override a built-in one */
border: 1px solid var(--wiki-content-border-color) !important;
}
/****************************
* End Special:MultiPageEdit *
*****************************/
/***********************
* Theme-based msupload *
************************/
#msupload-div,
#msupload-list .file {
background-color: var(--wiki-content-background-color);
border-color: var(--wiki-content-border-color);
}
#msupload-select {
filter: brightness(0) var(--wiki-icon-to-link-filter);
}
#msupload-dropzone {
border-color: var(--wiki-content-border-color);
color: var(--wiki-content-text-color);
}
.drop-over {
background-color: var(--wiki-accent-color);
color: var(--wiki-accent-label-color) !important;
}
#msupload-bottom {
border-color: var(--wiki-content-border-color);
}
#msupload-bottom #msupload-files {
padding-left: 0;
background: none;
}
#msupload-bottom #msupload-files::before {
display: inline-block;
background: url(/extensions/MsUpload/resources/images/msu-upload-icon.png?bdd61) no-repeat 0 0;
background-position: left center;
height: 22px;
width: 25px;
content: '';
vertical-align: top;
filter: var(--wiki-icon-general-filter);
}
#msupload-list .file .file-size {
color: var(--wiki-content-text-mix-color);
}
#msupload-div a {
color: var(--wiki-content-link-color);
}
#msupload-list .file .file-name:hover {
background-color: var(--wiki-content-dynamic-color--inverted);
}
#msupload-list .file .file-name-input {
background: var(--wiki-content-dynamic-color--inverted);
}
#msupload-list .file .file-warning {
color: var(--wiki-warning-color);
}
/***************************
* End theme-based msupload *
****************************/
/*****************************
* Theme-based commentstreams *
******************************/
.cs-title-edit-field {
border-color: var(--wiki-accent-color);
}
.cs-title-edit-field::placeholder,
.view-dark .cs-body-edit-field::placeholder {
color: var(--wiki-content-text-mix-color);
}
.cs-edit-box,
.cs-expanded .cs-comment-header {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.cs-target-comment .cs-comment-header {
border-color: var(--wiki-accent-color);
}
.cs-comment-author a {
color: var(--wiki-content-link-color);
}
.cs-comment-details {
color: color-mix(in srgb, var(--wiki-content-text-color) 95%, transparent);
}
.cs-comment-author-anonymous {
color: color-mix(in srgb, var(--wiki-content-text-color) 95%, transparent);
}
.cs-comment {
border: 1px solid var(--wiki-content-border-color);
}
.cs-comment-body {
padding: 0 5px;
}
/*********************************
* End theme-based commentstreams *
**********************************/
/************************
* Theme-based checkuser *
*************************/
.mw-datatable.ext-checkuser-investigate-table tr:hover td {
background-color: var(--wiki-content-background-color);
}
.mw-datatable.ext-checkuser-investigate-table th {
background-color: var(--wiki-content-background-color--secondary);
}
.ext-checkuser-investigate-table.mw-datatable.ext-checkuser-investigate-table-pinned .ext-checkuser-investigate-table-row-pinned td,
.ext-checkuser-investigate-table.mw-datatable.ext-checkuser-investigate-table-pinned .ext-checkuser-investigate-table-row-pinned-data-match td,
.ext-checkuser-investigate-table.mw-datatable:not(.ext-checkuser-investigate-table-pinned) .ext-checkuser-investigate-table-row-hover-data-match td,
.ext-checkuser-investigate-table.mw-datatable:not(.ext-checkuser-investigate-table-pinned) tr:hover td {
background-color: color-mix(in srgb, var(--wiki-warning-color) 10%, transparent);
}
.ext-checkuser-investigate-table.mw-datatable.ext-checkuser-investigate-table-pinned .ext-checkuser-investigate-table-row-pinned td.ext-checkuser-investigate-table-cell-pinned,
.ext-checkuser-investigate-table.mw-datatable.ext-checkuser-investigate-table-pinned .ext-checkuser-investigate-table-row-pinned-data-match td.ext-checkuser-investigate-table-cell-pinned,
.ext-checkuser-investigate-table.mw-datatable.ext-checkuser-investigate-table-pinned .ext-checkuser-investigate-table-row-pinned td.ext-checkuser-investigate-table-cell-pinned-data-match,
.ext-checkuser-investigate-table.mw-datatable.ext-checkuser-investigate-table-pinned .ext-checkuser-investigate-table-row-pinned-data-match td.ext-checkuser-investigate-table-cell-pinned-data-match,
.ext-checkuser-investigate-table.mw-datatable:not(.ext-checkuser-investigate-table-pinned) tr td.ext-checkuser-investigate-table-cell-hover-data-match,
.ext-checkuser-investigate-table.mw-datatable:not(.ext-checkuser-investigate-table-pinned) tr td:hover.ext-checkuser-investigate-table-cell-pinnable {
background-color: color-mix(in srgb, var(--wiki-warning-color) 40%, transparent);
}
.ext-checkuser-investigate-copy-message.oo-ui-messageWidget.oo-ui-messageWidget-block.oo-ui-flaggedElement-notice {
background-color: var(--wiki-content-background-color--secondary);
border-color: var(--wiki-content-border-color);
}
.mw-special-Investigate .ext-checkuser-investigate-subtitle-fieldset {
background-color: var(--wiki-content-background-color--secondary);
}
/****************
* End checkuser *
*****************/
/***************************
* Theme-based SearchDigest *
****************************/
.searchdigest-stats-table {
border-color: var(--wiki-content-border-color);
border-collapse: collapse;
}
.searchdigest-stats-table thead th,
.searchdigest-stats-table tr:not(:last-child) th,
.searchdigest-stats-table tr:not(:last-child) td {
border-bottom-color: var(--wiki-content-border-color);
}
.searchdigest-stats-table thead th:last-child,
.searchdigest-stats-table td {
border-left-color: var(--wiki-content-border-color);
}
.searchdigest-stats-table thead tr {
background: var(--wiki-content-background-color--secondary);
}
/*******************
* End SearchDigest *
********************/
/****************************
* Extension:RelatedArticles *
*****************************/
.client-js .read-more-container {
min-height: unset;
}
@media (min-width: 1000px) {
.client-js .read-more-container {
min-height: calc(
80px/*card height*/
+ 10px/*card margin*/
+ 1em/*container padding*/
+ 0.3em/*card-list margin*/
+ 0.8em/*h2 font-size*/
+ 1em/*h2 padding*/
+ 0.6em/*h2 margin*/
+ 1px /*container border*/
);
}
}
.ext-related-articles-card-list .ext-related-articles-card {
background-color: var(--wiki-content-background-color);
}
.ext-related-articles-card-list .ext-related-articles-card,
.ext-related-articles-card-list .ext-related-articles-card + .ext-related-articles-card { /* your guess is as good as mine for why they did this */
border-color: color-mix(in srgb, var(--wiki-content-border-color) 20%, transparent);
}
.ext-related-articles-card-list .ext-related-articles-card-thumb {
background-color: var(--wiki-content-background-color--secondary);
}
.ra-read-more h2 {
color: var(--wiki-body-dynamic-color--secondary);
}
.ext-related-articles-card-list h3 a {
color: var(--wiki-content-heading-color);
}
.ext-related-articles-card-list h3::after {
background-image: linear-gradient(to right, transparent, var(--wiki-content-background-color) 50%);
}
.ext-related-articles-card-list .ext-related-articles-card-extract {
color: color-mix(in srgb, var(--wiki-content-text-color) 50%, transparent);
}
/* removed background image and use a mask image instead */
.ext-related-articles-card-list .ext-related-articles-card-thumb-placeholder {
position: relative;
background-image: none;
}
.ext-related-articles-card-list .ext-related-articles-card-thumb-placeholder::after {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
content: '';
--mask-image: url("/extensions/RelatedArticles/resources/ext.relatedArticles.readMore/article.svg?3c572");
--mask-size: 40px;
--mask-repeat: no-repeat;
--mask-position: center;
-webkit-mask: var(--mask-image);
mask: var(--mask-image);
-webkit-mask-size: var(--mask-size);
mask-size: var(--mask-size);
-webkit-mask-repeat: var(--mask-repeat);
mask-repeat: var(--mask-repeat);
-webkit-mask-position: var(--mask-position);
mask-position: var(--mask-position);
background-color: color-mix(in srgb, var(--wiki-content-text-color) 75%, transparent);
}
/**/
/* this simulates mw-footer having a top border */
.read-more-container {
border-bottom: var(--wiki-content-border-width, 1px) solid var(--wiki-content-border-color);
}
@media screen and (min-width: 720px) {
.read-more-container {
margin-right: 1em;
}
}
/********************************
* End Extension:RelatedArticles *
*********************************/
/*******************
* Extension:Popups *
********************/
.mwe-popups {
box-shadow: 0 30px 90px -20px rgba(0, 0, 0, 0.3), 0 0 1px 1px color-mix(in srgb, var(--wiki-content-border-color) 5%, transparent);
}
.mwe-popups,
.mwe-popups .mwe-popups-container {
background-color: var(--wiki-content-background-color);
color: var(--wiki-content-text-color);
}
.mwe-popups .mwe-popups-extract {
color: var(--wiki-content-text-color);
}
.mwe-popups .mwe-popups-extract[dir="ltr"]::after {
background-image: linear-gradient(to right, transparent, var(--wiki-content-background-color) 50%);
}
.mwe-popups.flipped-y::before,
.mwe-popups.flipped-x-y::before,
.mwe-popups.mwe-popups-image-pointer::before,
.mwe-popups.mwe-popups-image-pointer.flipped-x::before,
.mwe-popups.mwe-popups-no-image-pointer::before,
.mwe-popups.flipped-x.mwe-popups-is-tall::before,
.mwe-popups.flipped-x-y.mwe-popups-is-tall::before {
border-color: var(--wiki-content-border-color);
}
.mwe-popups.flipped-y::after,
.mwe-popups.flipped-x-y::after,
.mwe-popups.mwe-popups-image-pointer::after,
.mwe-popups.mwe-popups-image-pointer.flipped-x::after,
.mwe-popups.mwe-popups-no-image-pointer::after,
.mwe-popups.flipped-x-y.mwe-popups-is-tall::after {
border-color: var(--wiki-content-background-color);
}
.popups-icon {
position: relative;
background-position: center;
background-repeat: no-repeat;
background-size: calc(max(1.4285714em, 20px));
min-width: 20px;
min-height: 20px;
width: 1.4285714em;
height: 1.4285714em;
display: inline-block;
vertical-align: text-bottom;
}
.popups-icon--preview-generic,
.popups-icon--settings,
.popups-icon--infoFilled,
.popups-icon--infoFilled:lang(ar),
.popups-icon--close,
.popups-icon--reference-generic,
.popups-icon--reference-book,
.popups-icon--preview-disambiguation {
background-image: none;
}
.popups-icon::after {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
content: '';
-webkit-mask-image: var(--mask-image, none);
mask-image: var(--mask-image, none);
-webkit-mask-repeat: var(--mask-repeat, no-repeat);
mask-repeat: var(--mask-repeat, no-repeat);
-webkit-mask-size: var(--mask-size, calc(max(1.4285714em, 20px)));
mask-size: var(--mask-size, calc(max(1.4285714em, 20px)));
-webkit-mask-position: var(--mask-position, center);
mask-position: var(--mask-position, center);
background-color: var(--mask-color, currentColor);
background-color: var(--mask-color, currentColor);
}
.popups-icon--preview-generic::after {
--mask-image: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2220%22 height=%2220%22 viewBox=%220 0 20 20%22%3E %3Ctitle%3E sad face %3C/title%3E %3Cpath d=%22M2 0a2 2 0 0 0-2 2v18l4-4h14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm4 4c1.336 0 2.007 1.617 1.06 2.56-.943.947-2.56.276-2.56-1.06A1.5 1.5 0 0 1 6 4zm8 0c1.336 0 2.007 1.617 1.06 2.56-.943.947-2.56.276-2.56-1.06A1.5 1.5 0 0 1 14 4zm-4 5c2.61 0 4.83.67 5.65 3H4.35C5.17 9.67 7.39 9 10 9z%22/%3E %3C/svg%3E");
}
.popups-icon--settings::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><g transform=\"translate(10 10)\"><path id=\"cdx-icon-settings-a\" d=\"M1.5-10h-3l-1 6.5h5m0 7h-5l1 6.5h3\"/><use xlink:href=\"%23cdx-icon-settings-a\" transform=\"rotate(45)\"/><use xlink:href=\"%23cdx-icon-settings-a\" transform=\"rotate(90)\"/><use xlink:href=\"%23cdx-icon-settings-a\" transform=\"rotate(135)\"/></g><path d=\"M10 2.5a7.5 7.5 0 000 15 7.5 7.5 0 000-15v4a3.5 3.5 0 010 7 3.5 3.5 0 010-7\"/></svg>");
}
.popups-icon--infoFilled::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M10 0C4.477 0 0 4.477 0 10s4.477 10 10 10 10-4.477 10-10S15.523 0 10 0zM9 5h2v2H9zm0 4h2v6H9z\"/></svg>");
}
.popups-icon--infoFilled:lang(ar)::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M8 19a1 1 0 001 1h2a1 1 0 001-1v-1H8zm9-12a7 7 0 10-12 4.9S7 14 7 15v1a1 1 0 001 1h4a1 1 0 001-1v-1c0-1 2-3.1 2-3.1A7 7 0 0017 7z\"/></svg>");
}
.popups-icon--close::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"m4.34 2.93 12.73 12.73-1.41 1.41L2.93 4.35z\"/><path d=\"M17.07 4.34 4.34 17.07l-1.41-1.41L15.66 2.93z\"/></svg>");
}
.popups-icon--reference-generic::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"m15 10-2.78-2.78L9.44 10V1H5a2 2 0 00-2 2v14a2 2 0 002 2h10a2 2 0 002-2V3a2 2 0 00-2-2z\"/></svg>");
}
.popups-icon--reference-book::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M15 2a7.65 7.65 0 00-5 2 7.65 7.65 0 00-5-2H1v15h4a7.65 7.65 0 015 2 7.65 7.65 0 015-2h4V2zm2.5 13.5H14a4.38 4.38 0 00-3 1V5s1-1.5 4-1.5h2.5z\"/><path d=\"M9 3.5h2v1H9z\"/></svg>");
}
.popups-icon--reference-journal::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M2 18.5A1.5 1.5 0 003.5 20H5V0H3.5A1.5 1.5 0 002 1.5zM6 0v20h10a2 2 0 002-2V2a2 2 0 00-2-2zm7 8H8V7h5zm3-2H8V5h8z\"/></svg>");
}
.popups-icon--reference-news::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M5 2a2 2 0 00-2 2v12a1 1 0 01-1-1V5h-.5A1.5 1.5 0 000 6.5v10A1.5 1.5 0 001.5 18H18a2 2 0 002-2V4a2 2 0 00-2-2zm1 2h11v4H6zm0 6h6v1H6zm0 2h6v1H6zm0 2h6v1H6zm7-4h4v5h-4z\"/></svg>");
}
.popups-icon--reference-web::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M2 2a2 2 0 00-2 2v12a2 2 0 002 2h16a2 2 0 002-2V4a2 2 0 00-2-2zm2 1.5A1.5 1.5 0 112.5 5 1.5 1.5 0 014 3.5zM18 16H2V8h16z\"/></svg>");
}
.popups-icon--preview-disambiguation::after {
--mask-image: url("data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"%23202122\"><path d=\"M7 0a2 2 0 00-2 2h9a2 2 0 012 2v12a2 2 0 002-2V2a2 2 0 00-2-2z\"/><path d=\"M13 20a2 2 0 002-2V5a2 2 0 00-2-2H4a2 2 0 00-2 2v13a2 2 0 002 2zM9 5h4v5H9zM4 5h4v1H4zm0 2h4v1H4zm0 2h4v1H4zm0 2h9v1H4zm0 2h9v1H4zm0 2h9v1H4z\"/></svg>");
}
/***********************
* End Extension:Popups *
************************/
/*************************
* Extension:CiteThisPage *
**************************/
.mw-specialCiteThisPage-bibliographic {
background-color:var(--wiki-content-background-color--secondary);
}
/*****************************
* End Extension:CiteThisPage *
******************************/
/*************************
* Extension:ImageMap *
**************************/
.noresize img { /* Why does the ImageMap container have no special class name? */
display: block; /* fix the scrollbar issue */
}
/*****************************
* End Extension:ImageMap *
******************************/
/*********************
* Mobile adjustments *
**********************/
/* Responsive Special:UserRights */
#mw-userrights-table-outer input#wpReason {
width: 100%;
max-width: 33.5em;
}
@media screen and (max-width: 720px) {
html:root { /* make it won't be override by user's common.css */
--wiki-is-top-logo: 1;
--wiki-left-spacing: 0px;
--wiki-right-spacing: 0px;
--wiki-navigation-left-spacing: 3px;
--wiki-navigation-right-spacing: 3px;
--wiki-content-border-radius: 0px;
--wiki-content-border-top-radius: 0px;
--wiki-footer-border-radius: 0px;
--wiki-content-padding: 0.5rem;
--wiki-navigation-menu-margin: 0.5rem; /* margin around toggle button and search box */
--wiki-navigation-height: calc(2rem + var(--wiki-is-navigation-inside-content, 0)*0.5em);
--wiki-navigation-bottom-padding: 0px;
--wiki-navigation-tab-height: 2rem;
--wiki-navigation-search-height: calc(2rem + 4px);
--wiki-navigation-right-spacing: var(--wiki-navigation-left-spacing, 0px);
--wiki-logo-height: 80px;
--wiki-logo-margin: 10px;
--wiki-navigation-tab-full-height: calc(var(--wiki-navigation-tab-height) + max(var(--wiki-navigation-selected-border-width), var(--wiki-navigation-border-width)) + var(--wiki-content-border-width, 1px));
--wiki-head-icon-padding: 0.25rem;
--wiki-head-icon-size: calc(var(--wiki-navigation-tab-height) - var(--wiki-head-icon-padding) * 2);
--wiki-head-toggle-button-size: var(--wiki-navigation-search-height);
--wiki-sidebar-portal-spacing: 0px;
--wiki-top-spacing: var(--wiki-logo-margin);
--wiki-logo-box-width: calc(min( var(--wiki-logo-file-width, 160) / var(--wiki-logo-file-height, 160) * var(--wiki-logo-height), calc(100vw - var(--wiki-navigation-menu-margin)*2 - 18px)));
}
#mw-head-base {
width: auto;
margin-left: auto;
margin-right: auto;
}
#p-logo {
max-width: 100vw;
top: calc(var(--wikigg-header-height) + var(--wiki-top-spacing, var(--wiki-logo-margin, 15px)));
left: calc(max(0px, (100% - var(--wiki-logo-file-width) / var(--wiki-logo-file-height) * var(--wiki-logo-box-height)) / 2));
}
#mw-head {
position: absolute;
left: 0;
width: 100%;
margin: unset;
top: calc(var(--wikigg-header-height) + var(--wiki-top-spacing, var(--wiki-logo-margin)) + var(--wiki-logo-box-height) + var(--wiki-logo-margin));
border-radius: 0;
}
#left-navigation::before { /* for left spacing */
border-bottom-width: var(--navigation-border-bottom-width);
}
#right-navigation::after {
display: block; /* for right spacing */
}
#p-cactions, #p-variants {
margin-right: 0px;
}
#p-cactions::after, #p-variants::after {
width: 0;
}
#p-search {
position: absolute;
left: var(--wiki-navigation-menu-margin);
right: var(--wiki-navigation-menu-margin);
top: calc(var(--wiki-navigation-height, 3em) + var(--navigation-border-bottom-width));
margin: 0;
padding: 0;
}
#mw-head::before, #mw-head::after,
#p-search::before, #p-search::after {
display: none;
}
#simpleSearch {
width: auto;
max-width: unset; /* override vector default of 20em */
}
.vector-search-box-input {
height: var(--wiki-navigation-search-height);
}
.vector-search-box form {
margin: var(--wiki-navigation-menu-margin) 0px;
}
#mw-head,
.mw-body, .parsoid-body,
.mw-body::after, .parsoid-body::after,
.mw-footer {
border-left-width: 0;
border-right-width: 0;
border-radius: 0;
}
.mw-body, .parsoid-body {
margin-top: 0;
padding-top: calc(var(--navigation-border-bottom-width) + var(--wiki-content-padding) + var(--wiki-navigation-search-height) + var(--wiki-navigation-bottom-padding) + (var(--wiki-navigation-menu-margin) * 2));
}
.mw-body::after, .parsoid-body::after {
left: 0;
right: 0;
}
#mw-data-after-content {
margin-left: 0;
}
#mw-panel {
position: unset;
width: 100%;
margin: 0px auto;
top: 0;
float: unset;
}
/* border-radius fix */
#mw-panel #p-ext-discordwidget + .vector-menu-portal {
border-radius: calc(min(var(--wiki-sidebar-border-radius), var(--wiki-sidebar-portal-spacing) * 999));
}
.vector-menu-dropdown .vector-menu-content {
right: 0;
left: unset;
}
#mw-panel .vector-menu-portal {
box-sizing: border-box;
border-left-width: 0;
border-right-width: 0;
background-color: var(--wiki-sidebar-background-color);
}
.vector-menu-portal .vector-menu-content {
margin-top: 0;
margin-bottom: 0;
display: block !important; /* show all menus on mobile even if they are collapsed by collapsibleSidebarSections gadget */
}
table.wikitable,
table.responsive-table {
display: block;
overflow-x: auto;
border: 0;
}
.mw-installed-software {
word-break: unset;
}
.gallerybox,
.gallerybox > div,
.gallerybox .thumb {
max-width: 100%;
}
/* disable float on RecentChanges legend */
.mw-changeslist-legend {
float: none;
margin: 0 auto;
}
/* advanced search options */
#mw-searchoptions table {
float: none;
}
#mw-searchoptions table td {
display: block;
}
/* popup when clicking the download button in multimediaviewer */
.mw-mmv-dialog {
width: unset;
}
/* turn math elements into scroll blocks unless they're an immediate child of a span */
:not(span) > math.mwe-math-element {
overflow: auto hidden;
max-width: 100%;
}
/* Expandable mobile navigation panel */
body.has-vector-mobile-menu #mw-panel {
position: absolute;
--panel-offset: calc(var(--wiki-head-toggle-button-size) + var(--wiki-sidebar-offset, 0px));
top: calc(var(--wikigg-header-height) + var(--wiki-top-spacing, var(--wiki-logo-margin, 15px)) + var(--wiki-logo-box-height) + var(--wiki-logo-margin, 15px) + var(--wiki-content-border-width, 1px) * var(--wiki-is-navigation-inside-content, 0px) + var(--wiki-navigation-height, 3em) + var(--navigation-border-bottom-width) + var(--wiki-navigation-menu-margin) + var(--panel-offset));
left: var(--wiki-navigation-menu-margin);
right: var(--wiki-navigation-menu-margin);
width: auto;
z-index: 3;
}
body.has-vector-mobile-menu #mw-panel:not(.nav--expanded){
padding: 0;
border: 0;
border-image: none;
}
body.has-vector-mobile-menu #mw-panel .mobile-nav-toggle {
position: absolute;
cursor: pointer;
z-index: 5;
display: flex;
justify-content: center;
align-items: center;
width: var(--wiki-head-toggle-button-size);
height: var(--wiki-head-toggle-button-size);
box-sizing: border-box;
appearance: none;
padding: 0;
border: 1px solid var(--wiki-content-border-color);
background-color: var(--wiki-navigation-background-color);
top: calc(-1 * var(--panel-offset));
}
#mw-panel #p-ext-discordwidget {
background-color: var(--wiki-sidebar-background-color);
padding: 0.5rem 0.25rem 0.25rem 0.5rem;
border: var(--wiki-sidebar-border-width, 1px) var(--wiki-sidebar-border-style, solid) var(--wiki-sidebar-border-color);
}
body.has-vector-mobile-menu #mw-panel .vector-menu-portal {
display: none;
border-image: none;
}
body.has-vector-mobile-menu #mw-panel .mobile-nav-toggle.nav--expanded ~ .vector-menu-portal {
display: block;
}
body.has-vector-mobile-menu #mw-navigation #mw-panel .vector-menu-portal {
text-align: left;
font-size: 110%;
border-left-width: var(--wiki-sidebar-border-width, 1px);
border-right-width: var(--wiki-sidebar-border-width, 1px);
margin-inline: var(--wiki-sidebar-margin, 0.5em);
}
body.has-vector-mobile-menu #mw-navigation #mw-panel .vector-menu-portal + .vector-menu-portal {
border-top-width: 0;
}
body.has-vector-mobile-menu #mw-navigation #mw-panel .vector-menu-portal:not(:last-child) {
border-bottom-width: 0;
}
body.has-vector-mobile-menu #mw-panel .vector-menu-content-list {
display: flex;
flex-wrap: wrap;
}
body.has-vector-mobile-menu #mw-panel .vector-menu-content-list a {
display: block;
padding: 0.2rem 0.5rem;
border: 1px solid transparent;
}
body.has-vector-mobile-menu #mw-panel .vector-menu-content-list a:hover {
border-color: var(--wiki-content-link-color);
}
body.has-vector-mobile-menu #mw-panel #p-navigation-label {
display: block;
}
body.has-vector-mobile-menu #p-logo {
/* Logo's a part of the sidebar panel, which uses relative positioning for the expandable button. Offset the logo appropriately. */
top: calc(-1 * (var(--wiki-logo-box-height) + var(--wiki-logo-margin, 15px) + var(--wiki-content-border-width, 1px) * var(--wiki-is-navigation-inside-content, 0) + var(--wiki-navigation-height, 3em) + var(--navigation-border-bottom-width) + var(--wiki-navigation-menu-margin) + var(--panel-offset)));
}
.mobile-nav-toggle {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='M1 3v2h18V3zm0 8h18V9H1zm0 6h18v-2H1z'/%3E%3C/svg%3E%0A");
}
body.has-vector-mobile-menu #p-tb .mw-list-item > a {
display: inline-flex;
}
body.has-vector-mobile-menu .vector-menu-content-list {
flex-direction: row;
}
/* Search adjustments for the expandable menu */
body.has-vector-mobile-menu #p-search {
/* reposition to the right when mobile sidebar menu is active */
left: calc(var(--wiki-navigation-menu-margin) * 2 + var(--wiki-head-toggle-button-size));
right: var(--wiki-navigation-menu-margin);
transform: none;
}
body.has-vector-mobile-menu #simpleSearch {
width: 100%;
margin: 0 auto;
}
/* icon navbar tabs + expandable nav panel icon */
#mw-head {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg fill='none' height='24' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h24v24H0z' fill='none' stroke='none'/%3E%3Cpath d='M4 4l4 16l4 -14l4 14l4 -16'/%3E%3C/svg%3E");
}
#mw-head .vector-menu-tabs .mw-list-item a,
#mw-head .vector-menu-dropdown .vector-menu-heading,
#mw-panel .mobile-nav-toggle {
line-height: var(--wiki-head-icon-size);
width: var(--wiki-head-icon-size); /* same as line height */
height: var(--wiki-head-icon-size);
box-sizing: content-box;
padding: var(--wiki-head-icon-padding);
color: transparent; /**<< for watch/unwatch, the text of <a> will be plain 'watch'/'unwatch' without <span> after clicking. **/
}
#mw-head .vector-menu-tabs .mw-list-item a::before,
#mw-head .vector-menu-dropdown .vector-menu-heading::before,
#mw-panel .mobile-nav-toggle::before {
content: "";
display: block;
position: unset;
background-image: none;
width: var(--wiki-head-icon-size);
height: var(--wiki-head-icon-size);
margin: 0;
--mask: var(--icon) no-repeat;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background-color: var(--wiki-navigation-text-color);
}
#mw-head .vector-menu-tabs .mw-list-item a:hover::before,
#mw-head .vector-menu-dropdown:hover .vector-menu-heading::before,
#mw-panel .mobile-nav-toggle:hover::before,
#mw-panel .mobile-nav-toggle.nav--expanded::before {
background-color: var(--wiki-navigation-text-color--hover, var(--wiki-content-link-color--hover)); /* fallback for backwards compatibility */
}
#mw-head .vector-menu-tabs .mw-list-item.selected a::before {
background-color: var(--wiki-navigation-selected-text-color);
}
#mw-head .vector-menu-tabs .mw-list-item a span,
#mw-head .vector-menu-dropdown .vector-menu-heading span {
display: none;
}
#mw-head .vector-menu-dropdown .vector-menu-heading::after {
display: none;
}
#ca-ve-edit,
#ca-edit {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='m16.77 8 1.94-2a1 1 0 0 0 0-1.41l-3.34-3.3a1 1 0 0 0-1.41 0L12 3.23zM1 14.25V19h4.75l9.96-9.96-4.75-4.75z'/%3E%3C/svg%3E%0A");
}
#ca-ve-edit + #ca-edit {
--icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='20' height='20' viewBox='0 0 20 20' aria-hidden='true'%3E%3C!----%3E%3Cg%3E%3Cpath d='M1 3v14h3v-2H3V5h1V3zm4 0v14h4v-2H7V5h2V3zm11 0v2h1v10h-1v2h3V3zm-5 0v2h2v10h-2v2h4V3z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
}
#ca-view,
#ca-view-foreign {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='M10 14.5a4.5 4.5 0 1 1 4.5-4.5 4.5 4.5 0 0 1-4.5 4.5M10 3C3 3 0 10 0 10s3 7 10 7 10-7 10-7-3-7-10-7'/%3E%3Ccircle cx='10' cy='10' r='2.5'/%3E%3C/svg%3E");
}
#left-navigation li[id^=ca-nstab-] {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Ctitle%3E article %3C/title%3E%3Cpath d='M5 1a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2zm0 3h5v1H5zm0 2h5v1H5zm0 2h5v1H5zm10 7H5v-1h10zm0-2H5v-1h10zm0-2H5v-1h10zm0-2h-4V4h4z'/%3E%3C/svg%3E%0A");
}
#ca-history {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='M9 6v5h.06l2.48 2.47 1.41-1.41L11 10.11V6z'/%3E%3Cpath d='M10 1a9 9 0 0 0-7.85 13.35L.5 16H6v-5.5l-2.38 2.38A7 7 0 1 1 10 17v2a9 9 0 0 0 0-18'/%3E%3C/svg%3E%0A");
}
#ca-talk {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg id='Outlined' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Ctitle/%3E%3Cg id='Fill'%3E%3Cpath d='M26,12H24V6a3,3,0,0,0-3-3H6A3,3,0,0,0,3,6V24.41l5.12-5.12A1.05,1.05,0,0,1,8.83,19H12v3a3,3,0,0,0,3,3h8.17a1.05,1.05,0,0,1,.71.29L29,30.41V15A3,3,0,0,0,26,12ZM12,15v2H8.83a3,3,0,0,0-2.12.88L5,19.59V6A1,1,0,0,1,6,5H21a1,1,0,0,1,1,1v6H15A3,3,0,0,0,12,15ZM27,25.59l-1.71-1.71A3,3,0,0,0,23.17,23H15a1,1,0,0,1-1-1V15a1,1,0,0,1,1-1H26a1,1,0,0,1,1,1Z'/%3E%3C/g%3E%3C/svg%3E");
}
#t-contributions {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg enable-background='new 0 0 32 32' id='Stock_cut' version='1.1' viewBox='0 0 32 32' xml:space='preserve' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cdesc/%3E%3Cpath d='M27,12V5h-7v0 c0-2.209-1.791-4-4-4h0c-2.209,0-4,1.791-4,4v0H1v7h0c2.209,0,4,1.791,4,4v0c0,2.209-1.791,4-4,4h0v11h11v0c0-2.209,1.791-4,4-4h0 c2.209,0,4,1.791,4,4v0h7V20h0c2.209,0,4-1.791,4-4v0C31,13.791,29.209,12,27,12L27,12z' fill='none' stroke='%23000000' stroke-linejoin='round' stroke-miterlimit='10' stroke-width='2'/%3E%3C/svg%3E");
}
#ca-addsection {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg id='Outlined' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Ctitle/%3E%3Cg id='Fill'%3E%3Cpolygon points='29 15 17 15 17 3 15 3 15 15 3 15 3 17 15 17 15 28 17 28 17 17 29 17 29 15'/%3E%3C/g%3E%3C/svg%3E");
}
#ca-viewsource {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath class='heroicon-ui' d='M20.59 12l-3.3-3.3a1 1 0 1 1 1.42-1.4l4 4a1 1 0 0 1 0 1.4l-4 4a1 1 0 0 1-1.42-1.4l3.3-3.3zM3.4 12l3.3 3.3a1 1 0 0 1-1.42 1.4l-4-4a1 1 0 0 1 0-1.4l4-4a1 1 0 0 1 1.42 1.4L3.4 12zm7.56 8.24a1 1 0 0 1-1.94-.48l4-16a1 1 0 1 1 1.94.48l-4 16z'/%3E%3C/svg%3E");
}
#p-variants {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' %3F%3E%3Csvg id='Outlined' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Ctitle/%3E%3Cg id='Fill'%3E%3Cpath d='M16,2A14,14,0,1,0,30,16,14,14,0,0,0,16,2Zm8,13a24.28,24.28,0,0,0-.41-3.62c2.19.91,3.75,2.19,4.25,3.62Zm-2,0H17V10a20.9,20.9,0,0,1,4.34.63A20.26,20.26,0,0,1,22,15ZM17,8V4.19c1.43.5,2.71,2.06,3.62,4.25A24.28,24.28,0,0,0,17,8ZM15,4.19V8a24.28,24.28,0,0,0-3.62.41C12.29,6.25,13.57,4.69,15,4.19ZM15,10v5H10a20.26,20.26,0,0,1,.63-4.34A20.9,20.9,0,0,1,15,10ZM8,15H4.19c.5-1.43,2.06-2.71,4.25-3.62A24.28,24.28,0,0,0,8,15Zm0,2a24.28,24.28,0,0,0,.41,3.62C6.25,19.71,4.69,18.43,4.19,17Zm2,0h5v5a20.9,20.9,0,0,1-4.34-.63A20.26,20.26,0,0,1,10,17Zm5,7v3.84c-1.43-.5-2.71-2.06-3.62-4.25A24.28,24.28,0,0,0,15,24Zm2,3.84V24a24.28,24.28,0,0,0,3.62-.41C19.71,25.75,18.43,27.31,17,27.81ZM17,22V17h5a20.26,20.26,0,0,1-.63,4.34A20.9,20.9,0,0,1,17,22Zm7-5h3.84c-.5,1.43-2.06,2.71-4.25,3.62A24.28,24.28,0,0,0,24,17Zm2.87-6.12A15.11,15.11,0,0,0,23,9a15.11,15.11,0,0,0-1.85-3.87A12.12,12.12,0,0,1,26.84,10.88Zm-16-5.72A15.11,15.11,0,0,0,9,9a15.11,15.11,0,0,0-3.87,1.85A12.12,12.12,0,0,1,10.88,5.16Zm-5.72,16A15.11,15.11,0,0,0,9,23a15.11,15.11,0,0,0,1.85,3.87A12.12,12.12,0,0,1,5.16,21.12Zm16,5.72A15.11,15.11,0,0,0,23,23a15.11,15.11,0,0,0,3.87-1.85A12.12,12.12,0,0,1,21.12,26.84Z'/%3E%3C/g%3E%3C/svg%3E");
}
#p-cactions {
--icon: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Ccircle cx='3' cy='10' r='2'/%3E%3Ccircle cx='17' cy='10' r='2'/%3E%3C/svg%3E%0A");
}
#ca-watch {
--icon: var(--icon-star-empty);
}
#ca-unwatch {
--icon: var(--icon-star-filled);
}
.vector-menu-tabs #ca-watch.icon a:hover::before,
.vector-menu-tabs #ca-unwatch.icon a:hover::before {
background-image: none;
}
/* RecentChanges - prevent overflow on long summaries */
.client-js .mw-changeslist ul,
.client-js .mw-changeslist table.mw-enhanced-rc {
margin-left: 0;
}
.mw-changeslist-line-inner-comment,
.mw-changeslist-line .comment {
font-size: 0.9em;
}
.mw-userlink {
overflow-wrap: anywhere;
}
}
/* Hide the expandable navigation button for desktop users */
.mobile-nav-toggle {
display: none;
}
/*************
* End mobile *
**************/
/******************************************************/
/* */
/* [END] OF WIKI.GG DEFAULT LOADOUT */
/* ALL LOCAL SKIN CUSTOMIZATIONS SHOULD GO BELOW HERE */
/* DO NOT EDIT OR DELETE THIS COMMENT BLOCK */
/* */
/******************************************************/
737acde73ae5c553a98604c85f569e2b26fd8696
MediaWiki:Common.css
8
235
259
2025-08-20T01:24:55Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* CSS placed here will be applied to all skins */
/******************************************************************************************
********************************* Start user-edit variables *******************************
******************************************************************************************/
/*****************************************
****** START BASIC DESIGN VARIABLES ******
----------------------------------------*/
:root {
--wiki-content-heading-font-family: 'Linux Libertine', 'Georgia', 'Times', serif;
--wiki-sidebar-heading-font-family: sans-serif;
--wiki-content-border-radius: 0px;
--wiki-sidebar-border-radius: 0px;
}
/*----------------------------------------
******* END BASIC DESIGN VARIABLES *******
*****************************************/
/*****************************************
****** START BASIC COLOR VARIABLES *******
----------------------------------------*/
:root,
/* Begin light styles, delete from here to "end light styles" if you don't want your wiki to support any light themes (remove from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=light, */
/* individual themes are prefixed with .theme- instead */
.view-light {
/**********************
* Probably edit these * [ LIGHT VIEW ]
***********************/
--wiki-body-background-color: #F6F6F6;
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-content-background-color: #ffffff;
--wiki-content-background-opacity: 100%;
--wiki-content-border-color: #a7d7f9;
--wiki-content-link-color: #0645ad; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ LIGHT VIEW ] */
--wiki-accent-color: #3366cc;
--wiki-accent-label-color: #ffffff;
--wiki-accent-link-color: #D5FB51;
--wiki-icon-to-link-filter: invert(20%) sepia(93%) saturate(2141%) hue-rotate(210deg) brightness(83%) contrast(103%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* end light styles */
/* Begin dark styles, delete from here to "end dark styles" if you don't want your wiki to support any dark themes (remove it from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=dark, */
/* individual themes are prefixed with .theme- instead */
.view-dark {
/**********************
* Probably edit these * [ DARK VIEW ]
***********************/
--wiki-body-background-color: #171717;
--wiki-body-background-image: url(filepath://Site-background-dark.jpg);
--wiki-content-background-color: #202020;
--wiki-content-background-opacity: 90%;
--wiki-content-border-color: #991A51;
--wiki-content-link-color: #6d8afb; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ DARK VIEW ] */
--wiki-accent-color: #ff4d9d;
--wiki-accent-label-color: #000;
--wiki-accent-link-color: #1e1e43;
--wiki-icon-to-link-filter: invert(60%) sepia(70%) saturate(3715%) hue-rotate(206deg) brightness(101%) contrast(97%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* End dark styles */
/*----------------------------------------
******* END BASIC COLOR VARIABLES ********
*****************************************/
/*****************************************
**** START ADVANCED COLOR VARIABLES ******
----------------------------------------*/
:root,
.view-light {
/*******************
* Maybe edit these * [ LIGHT VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #111111;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #ba0000;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ LIGHT VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ LIGHT VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #bf0017;
--wiki-warning-color: #b05f30;
--wiki-success-color: #0c742f;
/**/
/***********************************
* Likely do not need to edit these * [ LIGHT VIEW ]
************************************/
--wiki-body-dynamic-color: #000000;
--wiki-body-dynamic-color--inverted: #ffffff;
--wiki-body-dynamic-color--secondary: #333333;
--wiki-body-dynamic-color--secondary--inverted: #cccccc;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #ffffff;
--wiki-content-dynamic-color: #000000;
--wiki-content-dynamic-color--inverted: #ffffff;
--wiki-content-dynamic-color--secondary: #333333;
--wiki-content-dynamic-color--secondary--inverted: #cccccc;
/* [ LIGHT VIEW ] */
--wiki-alert-label-color: #ffffff;
--wiki-warning-label-color: #ffffff;
--wiki-success-label-color: #ffffff;
--wiki-icon-general-filter: ; /* do not set this to none, ignore the "unexpected token" error */
/**/
}
.view-dark {
/*******************
* Maybe edit these * [ DARK VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #ededed;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #FC5B4F;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ DARK VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ DARK VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #ff576a;
--wiki-warning-color: #cf721c;
--wiki-success-color: #13aa45;
/**/
/***********************************
* Likely do not need to edit these * [ DARK VIEW ]
************************************/
--wiki-body-dynamic-color: #ffffff;
--wiki-body-dynamic-color--inverted: #000000;
--wiki-body-dynamic-color--secondary: #cccccc;
--wiki-body-dynamic-color--secondary--inverted: #333333;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #000;
--wiki-content-dynamic-color: #ffffff;
--wiki-content-dynamic-color--inverted: #000000;
--wiki-content-dynamic-color--secondary: #cccccc;
--wiki-content-dynamic-color--secondary--inverted: #333333;
/* [ DARK VIEW ] */
--wiki-alert-label-color: #000000;
--wiki-warning-label-color: #000000;
--wiki-success-label-color: #000000;
--wiki-icon-general-filter: invert(100%);
}
/*----------------------------------------
***** END ADVANCED COLOR VARIABLES *******
*****************************************/
/*****************************************
**** START ADVANCED DESIGN VARIABLES *****
----------------------------------------*/
:root {
/***********************
start logo position
----------------------*/
--wiki-is-top-logo: 0; /* 1 = center logo at the top of the page; 0 = logo at the top left of the page */
--wiki-logo-file-width: 160; /* Width of the image file in px. Put a number without the letters `px`. */
--wiki-logo-file-height: 160; /* Height of the image file in px. Put a number without the letters `px`. */
--wiki-logo-height: calc(var(--wiki-logo-file-height)*1px); /* Valid only when --wiki-is-top-logo is 1. The height the logo should be shown */
--wiki-logo-margin: 15px; /* the width of margin below the logo. When --wiki-is-top-logo is 1, this is also the default value of --wiki-top-spacing */
/*-----------------------
end logo position
***********************/
--wiki-is-navigation-inside-content: 0; /* 0 = default navigation tabs layout; 1 = navigation tabs inside content box */
--wiki-body-font-family: sans-serif;
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family); /* only apply to the main title of article */
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-width: 1px;
--wiki-sidebar-width: 10em; /* width of sidebar(#mw-panel) */
--wiki-sidebar-portal-spacing: 0px;
--wiki-sidebar-border-width: var(--wiki-content-border-width);
--wiki-navigation-border-radius: 0px; /* border radius of tabs */
/*******************
* Maybe edit these * [ DESIGN ]
********************/
--wiki-logo-filter: none;
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-top-radius: var(--wiki-content-border-radius);
--wiki-content-border-style: solid;
--wiki-content-border-image: none;
--wiki-content-backdrop-filter: none;
--wiki-page-content-max-width: 9999px; /* max width of sidebar+gap+content, must be a length value. A huge value can be used to indicate no limit, e.g. 99999px */
--wiki-gap-between-sidebar-and-content: 0.5em; /* gap between sidebar(#mw-panel) and content(#content) */
--wiki-sidebar-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-heading-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-margin: 0.5em;
--wiki-sidebar-list-item-padding: 0.25em 0.25rem;
--wiki-sidebar-list-padding: 0.25rem;
--wiki-sidebar-list-item-background--hover: none; /* background of hover item */
--wiki-navigation-font-size: 0.8125em; /* please use em or rem for this */
--wiki-navigation-height: 2.75rem; /* height of navigation area,include spacing above tabs */
--wiki-navigation-left-spacing: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-radius) + var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-right-spacing: calc( var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-box-background-color: var(--wiki-content-background-color);
--wiki-navigation-box-background-opacity: calc(var(--wiki-content-background-opacity)*0.8*var(--wiki-is-navigation-inside-content));
--wiki-navigation-box-background: color-mix(in srgb, var(--wiki-navigation-box-background-color) var(--wiki-navigation-box-background-opacity), transparent); /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-border-image: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-backdrop-filter: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-selected-backdrop-filter: var(--wiki-content-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
--wiki-navigation-backdrop-filter: var(--wiki-navigation-selected-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
/* nav tabs style. The vector gradient is default.
* If you want to customize the style of tabs, it's easier to start with the following settings:
* --wiki-navigation-background-image: none;
* --wiki-navigation-selected-background-image: none;
* --wiki-navigation-selected-border-width: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-width) + var(--wiki-is-navigation-inside-content) * 1px );
* --wiki-navigation-selected-border-bottom-background: none;
* --wiki-navigation-tab-spacing: 0.25em;
* --wiki-navigation-tab-padding-top: 0.5em;
* --wiki-navigation-tab-padding-bottom: 0.5em;
*/
--wiki-navigation-tab-spacing: -1px; /* width of the space between tabs, can be a negative number, in which case adjacent tabs will overlap */
--wiki-navigation-tab-padding-top: 1.25em;
--wiki-navigation-tab-padding-x: 0.75em;
--wiki-navigation-tab-padding-bottom: 4px;
--wiki-navigation-selected-border-width: 0px; /* border width of selected tabs */
--wiki-navigation-border-width: var(--wiki-navigation-selected-border-width); /* border width of normal tabs */
--wiki-navigation-border-image: none;
--wiki-navigation-selected-border-image: var(--wiki-navigation-border-image);
--wiki-navigation-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to top,var(--wiki-navigation-background-color) 0,var(--wiki-navigation-selected-background-color) 100%);
--wiki-navigation-background-repeat: no-repeat, no-repeat, repeat-x;
--wiki-navigation-background-position: left bottom, right bottom, left bottom;
--wiki-navigation-background-size: 1px 100%, 1px 100%, 100%;
--wiki-navigation-selected-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%);
--wiki-navigation-selected-background-repeat: no-repeat, no-repeat;
--wiki-navigation-selected-background-position: left bottom, right bottom;
--wiki-navigation-selected-background-size: 1px 100%, 1px 100%;
--wiki-navigation-selected-border-bottom-background: linear-gradient(to right, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px), linear-gradient(to left, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px);
/* affects the dropdown menu under More */
--wiki-navigation-dropdown-text-color: var(--wiki-navigation-text-color);
--wiki-navigation-dropdown-text-color--hover: var(--wiki-navigation-dropdown-text-color);
--wiki-navigation-dropdown-font-size: var(--wiki-navigation-font-size); /* please use em or rem for this */
--wiki-navigation-dropdown-border-width: 1px;
--wiki-navigation-dropdown-border-radius: var(--wiki-navigation-border-radius);
--wiki-navigation-dropdown-padding: 0.25em; /* padding of the dropdown menu box */
--wiki-navigation-dropdown-item-padding: 0.625em; /* padding of each dropdown menu items */
--wiki-navigation-dropdown-item-background--hover: none; /* background of hover item */
--wiki-navigation-dropdown-border-image: none;
--wiki-navigation-dropdown-backdrop-filter: none;
--wiki-navigation-dropdown-box-shadow: none; /* box shadow */
/* styles of the footer */
--wiki-spacing-before-footer: 0px;
--wiki-footer-border-image: none;
/* padding on body element */
--wiki-top-spacing: calc(var(--wiki-is-top-logo)*var(--wiki-logo-margin) + (1 - var(--wiki-is-top-logo))*1em); /* extra spacing below wiki.gg netbar */
--wiki-left-spacing: 0.5em;
--wiki-right-spacing: 1em;
--wiki-bottom-spacing: 2em;
/* end design variables */
}
/*----------------------------------------
***** END ADVANCED DESIGN VARIABLES ******
*****************************************/
/*******************************
**** START SHARED VARIABLES ****
**** tl;dr: don't edit this ****
********************************/
/*
These variables are rarely touched, usually inherit other variables, and are shared on all themes.
In 99% of cases none of these are ever edited, and you should only be doing so if you have a very clear vision,
understand what you are doing, and *know* that what you are trying to do is not accomplished by changing
another variable in the above sections.
Since these are by default shared across all themes, if you support multiple themes you'll probably want to
separate the variables you want to modify here into .view-x blocks like above. If you don't understand
what that means or how to do that then you probably shouldn't be modifying this section.
*/
:root {
--wiki-content-border-bottom-width: var(--wiki-content-border-width);
--wiki-content-border-bottom-style: var(--wiki-content-border-style);
--wiki-content-border-bottom-color: var(--wiki-content-border-color);
--wiki-content-text-mix-color: color-mix(in srgb, var(--wiki-content-background-color), var(--wiki-content-text-color) 62%);
--wiki-content-text-mix-color-95: color-mix(in srgb, var(--wiki-content-background-color) 95%, var(--wiki-content-text-color));
--wiki-content-text-color--hover: var(--wiki-content-text-color);
/* heading */
--wiki-content-heading-border-bottom-width: 1px;
--wiki-content-heading-border-style: solid;
--wiki-content-heading-font-weight: normal;
--wiki-content-heading-font-style: normal;
--wiki-content-heading-text-transform: none;
--wiki-content-heading-line-height: normal;
--wiki-content-heading-text-shadow: none;
/* first heading (h1) */
--wiki-content-firstheading-border-bottom-width: var(--wiki-content-heading-border-bottom-width);
--wiki-content-firstheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-firstheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family);
--wiki-content-firstheading-font-weight: var(--wiki-content-heading-font-weight);
--wiki-content-firstheading-font-style: var(--wiki-content-heading-font-style);
--wiki-content-firstheading-text-transform: var(--wiki-content-heading-text-transform);
--wiki-content-firstheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-firstheading-color: var(--wiki-content-heading-color);
--wiki-content-firstheading-text-shadow: none;
/* sub-heading (h3, h4, h5, h6) */
--wiki-content-subheading-border-bottom-width: 0px;
--wiki-content-subheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-subheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-subheading-font-family: var(--wiki-body-font-family);
--wiki-content-subheading-font-weight: bold;
--wiki-content-subheading-font-style: normal;
--wiki-content-subheading-text-transform: none;
--wiki-content-subheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-subheading-color: var(--wiki-content-heading-color);
--wiki-content-subheading-text-shadow: none;
/* heading size */
--wiki-content-firstheading-font-size: 1.8em;
--wiki-content-heading-h2-font-size: 1.5em;
--wiki-content-heading-h3-font-size: 1.2em;
--wiki-content-heading-h4-font-size: 114%;
--wiki-content-heading-h5-font-size: 108%;
--wiki-content-heading-h6-font-size: 100%;
--wiki-content-toc-background: var(--wiki-content-background-color--secondary);
--wiki-content-toc-border-width: 1px;
--wiki-content-toc-border-style: solid;
--wiki-content-toc-border-color: var(--wiki-content-border-color);
--wiki-content-toc-border-radius: 0px;
--wiki-content-toc-border-image: none;
--wiki-content-toc-box-shadow: 0 0.1em 0.2em #000000;
--wiki-content-catlinks-background: var(--wiki-content-background-color--secondary);
--wiki-content-catlinks-border-width: 1px;
--wiki-content-catlinks-border-style: solid;
--wiki-content-catlinks-border-color: var(--wiki-content-border-color);
--wiki-content-catlinks-border-radius: 0px;
--wiki-content-catlinks-border-image: none;
--wiki-content-catlinks-box-shadow: none;
--wiki-content-filetoc-background: var(--wiki-content-background-color--secondary);
--wiki-content-filetoc-border-width: 1px;
--wiki-content-filetoc-border-style: solid;
--wiki-content-filetoc-border-color: var(--wiki-content-border-color);
--wiki-content-filetoc-border-radius: 0px;
--wiki-content-filetoc-border-image: none;
--wiki-content-filetoc-box-shadow: none;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
--wiki-sidebar-padding: 0px;
--wiki-sidebar-background-color: var(--wiki-content-background-color);
--wiki-sidebar-background-opacity: var(--wiki-content-background-opacity);
--wiki-sidebar-background-image: none;
--wiki-sidebar-background-position: center;
--wiki-sidebar-background-repeat: repeat;
--wiki-sidebar-background-size: auto;
--wiki-sidebar-filter: none;
--wiki-sidebar-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-sidebar-border-color: var(--wiki-content-border-color);
--wiki-sidebar-border-style: solid;
--wiki-sidebar-border-image: none;
--wiki-sidebar-link-color: var(--wiki-content-link-color);
--wiki-sidebar-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-sidebar-heading-color: var(--wiki-content-heading-color);
--wiki-sidebar-heading-font-weight: normal;
--wiki-sidebar-heading-font-style: normal;
--wiki-sidebar-heading-text-transform: none;
--wiki-sidebar-heading-line-height: normal;
--wiki-sidebar-heading-padding: 0.5rem 0.25rem 0.5rem 0.5rem;
--wiki-sidebar-heading-margin: 0px 0px -0.5rem 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-text-shadow: none;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-icon-to-link-filter: var(--wiki-icon-to-link-filter);
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-box-padding: 0px;
--wiki-sidebar-box-background: none;
--wiki-sidebar-box-border: 0px;
--wiki-sidebar-box-border-image: none;
--wiki-accent-color--hover: color-mix(in srgb, var(--wiki-accent-color) 90%, var(--wiki-accent-label-color));
--wiki-footer-border-width: var(--wiki-content-border-width);
--wiki-footer-border-style: var(--wiki-content-border-style);
--wiki-footer-border-color: var(--wiki-content-border-color);
--wiki-footer-background-color: var(--wiki-content-background-color);
--wiki-footer-background-opacity: var(--wiki-content-background-opacity);
--wiki-footer-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-footer-text-color: var(--wiki-content-text-color);
--wiki-footer-link-color: var(--wiki-content-link-color);
--wiki-footer-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-footer-border-radius: var(--wiki-content-border-radius);
--wiki-navigation-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-background-color--hover: var(--wiki-navigation-background-color);
--wiki-navigation-background-opacity--hover: var(--wiki-navigation-background-opacity);
--wiki-navigation-background-image--hover: var(--wiki-navigation-background-image);
--wiki-navigation-background-position--hover: var(--wiki-navigation-background-position);
--wiki-navigation-background-repeat--hover: var(--wiki-navigation-background-repeat);
--wiki-navigation-background-size--hover: var(--wiki-navigation-background-size);
--wiki-navigation-text-color--hover: var(--wiki-content-link-color--hover);
--wiki-navigation-transform--hover: none;
--wiki-navigation-selected-border-style: solid;
--wiki-navigation-selected-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-border-style: solid;
--wiki-navigation-border-color--hover: var(--wiki-navigation-border-color);
--wiki-navigation-border-image--hover: var(--wiki-navigation-border-image);
--wiki-navigation-border-bottom-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-border-bottom-style: var(--wiki-navigation-selected-border-style);
--wiki-navigation-border-bottom-width: calc(var(--wiki-is-navigation-inside-content, 0) * var(--wiki-navigation-selected-border-width, 1px) + (1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-width, 1px));
--wiki-navigation-icon-size: 1em;
--wiki-navigation-tab-padding-x--icon: var(--wiki-navigation-tab-padding-x);
--wiki-navigation-bottom-spacing: 0px; /* If you change this to greater than 0px, you should usually change the value of --wiki-navigation-selected-border-bottom-background to var(--wiki-navigation-border-bottom-color) */
--wiki-navigation-dropdown-background-color: var(--wiki-navigation-selected-background-color);
--wiki-navigation-dropdown-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-dropdown-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-dropdown-offset: 0px; /* vertical offset */
--wiki-navigation-search-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-search-background-image: none;
--wiki-navigation-search-background-position: 0;
--wiki-navigation-search-background-size: auto;
--wiki-navigation-search-background-repeat: repeat;
--wiki-navigation-search-backdrop-filter: none;
--wiki-navigation-search-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-search-border-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-border-style: solid;
--wiki-navigation-search-border-width: 1px;
--wiki-navigation-search-border-radius: 2px;
--wiki-navigation-search-border-image: none;
--wiki-navigation-search-border-image--hover: var(--wiki-navigation-search-border-image);
--wiki-navigation-search-box-shadow: none;
--wiki-navigation-search-box-shadow--hover: var(--wiki-navigation-search-box-shadow);
--wiki-navigation-search-text-color: var(--wiki-content-text-color);
--wiki-navigation-search-font-size: var(--wiki-navigation-font-size);
--wiki-navigation-search-height: 2em;
--wiki-navigation-search-button-color: currentColor;
--wiki-navigation-search-button-color--hover: var(--wiki-navigation-search-button-color);
--wiki-navigation-search-button-color-opacity: 80%;
--wiki-navigation-search-button-color-opacity--hover: 95%;
--wiki-navigation-search-bottom-spacing: 3px;
--wiki-navigation-search-highlight-background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
--wiki-navigation-gap-between-left-and-right: calc(max(0px, var(--wiki-navigation-tab-spacing))); /* minimum width between #left-navigation and #right-navigation before tabs start to collapse */
}
/*** mobile adjustments ***/
@media screen and (max-width: 720px) {
body.has-vector-mobile-menu{
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-margin: 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-margin: 0px 0px -0.5em 0px;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-background-opacity: 100%;
--wiki-navigation-search-border-width: 1px;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
}
}
/*****************************
**** END SHARED VARIABLES ****
******************************/
/******************************************************************************************
********************************* End user-edit variables *********************************
******************************************************************************************/
/******************************
* Fallback for older browsers *
* DONT EDIT THIS *
*******************************/
@supports not (color:color-mix(in srgb, #000, transparent)) {
.view-dark,
.view-light,
:root {
--wiki-content-text-mix-color: var(--wiki-content-text-color);
--wiki-content-text-mix-color-95: var(--wiki-content-background-color);
--wiki-content-background-color--secondary: var(--wiki-content-dynamic-color--secondary--inverted);
--wiki-content-border-color--secondary: var(--wiki-content-border-color);
--wiki-content-border-color--accent: var(--wiki-accent-color);
--wiki-accent-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-highlight-background-color: transparent;
}
}
/*****************************
* End older browser fallback *
******************************/
/*****************************
* PortableInfoboxes *
******************************/
:root {
--pi-background: var(--wiki-content-background-color);
--pi-secondary-background: var(--wiki-accent-color);
--pi-secondary-background-label: var(--wiki-accent-label-color);
--pi-border-color: color-mix(in srgb, var(--pi-secondary-background) 50%, transparent);
}
.portable-infobox .pi-title,
.portable-infobox .pi-header {
text-align: center;
font-size: 1.5em;
background: color-mix(in srgb, var(--pi-secondary-background) 75%, transparent);
color: var(--pi-secondary-background-label);
}
.portable-infobox .pi-data,
.portable-infobox .pi-group {
background: var(--wiki-content-background-color--secondary);
}
.portable-infobox .pi-image {
padding: 8px;
}
.pi-image-thumbnail {
max-width: 100%;
}
.pi-caption {
color: var(--wiki-content-text-mix-color);
}
.pi-section-navigation .pi-section-tab.pi-section-active,
.pi-section-navigation .pi-section-tab.current,
.pi-media-collection .pi-tab-link.current {
background: var(--pi-secondary-background);
color: var(--pi-secondary-background-label);
}
.pi-collapse > .pi-item:first-child {
cursor: pointer;
}
/* overqualify these to overwrite normal content heading styles */
.mw-body .portable-infobox h2,
.mw-body .portable-infobox h3 {
border-bottom: 0;
font-family: inherit;
font-weight: 700;
margin: 0;
}
/*****************************
* End PortableInfoboxes *
******************************/
/*******************
* Main page layout *
********************/
#mp-container {
display: grid;
gap: 10px;
}
@media screen and (max-width: 990px) {
/* for mobile screens */
#mp-container {
grid-template-areas:var(--main-page-layout--mobile);
grid-template-columns:var(--main-page-layout-columns--mobile, 100%);
}
.mp-box.mp-hide-on-mobile {
display: none;
}
}
@media screen and (min-width: 990px) and (max-width: 1350px) {
/* for narrow screens, between 990px and 1350px */
#mp-container {
grid-template-areas:var(--main-page-layout--tablet);
grid-template-columns:var(--main-page-layout-columns--tablet, 1fr 1fr);
}
.mp-box.mp-hide-on-tablet {
display: none;
}
}
@media screen and (min-width: 1350px) {
/* for all other screens, 1350px and wider */
#mp-container {
grid-template-areas:var(--main-page-layout--desktop);
grid-template-columns:var(--main-page-layout-columns--desktop, 2fr 1fr 2fr);
}
.mp-box.mp-hide-on-desktop {
display: none;
}
}
.mp-box {
position: relative;
display: flex;
flex-flow: column nowrap;
width: 100%;
box-sizing: border-box;
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 25%, transparent);
border: 1px solid var(--wiki-content-border-color);
padding: 0px;
}
.mp-body {
height: 100%;
display: flex;
padding: 0.5em;
flex-flow: column nowrap;
}
.mp-box.centered-content .mp-body {
height: 100%;
display: flex;
flex-flow: column nowrap;
justify-content: space-evenly;
}
.mp-box.has-floating-image {
display: block;
}
.mp-box.has-floating-image .mp-body {
height: unset;
display: block;
}
/* overqualified to override normal heading styles */
.mw-body .mp-box h2 {
text-align: center;
font-weight: bold;
font-family: var(--wiki-content-heading-font-family);
overflow: initial;
border-bottom: 1px solid var(--wiki-content-border-color);
font-size: 150%;
margin: 0;
padding: 5px 0;
color: var(--wiki-content-heading-color);
}
#mp-box-welcome {
text-align: center;
position: relative;
overflow: hidden;
}
#mp-box-welcome h2 {
font-size: 200%;
}
#mp-welcome {
display: flex;
flex-flow: column nowrap;
position: relative;
height: 100%;
z-index: 2;
box-sizing: border-box;
}
#mp-welcome .welcome-subtitle {
height: 100%;
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 85%, transparent);
padding: 0.5em;
}
#mp-banner {
position: absolute;
width: 100%;
height: 100%;
filter: blur(5px);
z-index: -1;
background: url(/images/e/e0/MP_banner.jpg);
background-size: cover;
background-repeat: no-repeat;
background-position: top center;
}
.view-dark #mp-banner {
filter: blur(5px) brightness(50%);
}
.view-light #mp-banner {
filter: blur(5px) contrast(50%);
}
/* [[Template:MP_link]] */
.mp-links {
--gap: 10px;
}
.mp-links > ul {
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin: 2px;
gap: var(--gap);
}
.mp-links > ul > li {
display: flex;
flex-flow: column nowrap;
align-items: stretch;
text-align: center;
box-sizing: border-box;
flex: max(calc(50% - var(--gap)), 5em) 1 1;
outline: 1px solid var(--wiki-content-link-color);
transition: 0.1s ease-in;
}
.mp-links > ul > li:hover {
background-color: color-mix(in srgb, var(--wiki-content-link-color) 20%, transparent);
}
.mp-links.columns-1 > ul > li {flex: max(calc(100% - var(--gap)), 5em) 1 1;}
.mp-links.columns-2 > ul > li {flex: max(calc(50% - var(--gap)), 5em) 1 1;}
.mp-links.columns-3 > ul > li {flex: max(calc((100% / 3) - var(--gap)), 5em) 1 1;}
.mp-links.columns-4 > ul > li {flex: max(calc(25% - var(--gap)), 5em) 1 1;}
.mp-links.columns-5 > ul > li {flex: max(calc(20% - var(--gap)), 5em) 1 1;}
.mp-links.columns-6 > ul > li {flex: max(calc((100% / 6) - var(--gap)), 5em) 1 1;}
.mp-links.columns-7 > ul > li {flex: max(calc((100% / 7) - var(--gap)), 5em) 1 1;}
.mp-links.columns-8 > ul > li {flex: max(calc((100% / 8) - var(--gap)), 5em) 1 1;}
.mp-links.columns-max > ul > li {flex: max(calc(0% - var(--gap)), 5em) 1 1;}
.mp-links > ul > li:hover a {
text-decoration: underline;
}
.mp-links > ul > li > a {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
flex: 1 1 auto;
box-sizing: border-box;
padding: 5px;
}
.mp-links > ul > li > a:first-child {
height: 100%;
}
.mp-links > ul > li > a:last-child:not(:first-child) {
height: unset;
}
.mp-links.stretch,
.mp-links.stretch > ul {
height: 100%;
}
.mp-links.side-image li {
flex-flow: row nowrap;
}
.mp-links.plain > ul > li {
outline-color: transparent;
}
/***********************
* End main page layout *
************************/
/*********************************************************************************************************************
* Semantically-correct horizontal lists (for Module:Navbox, and they're more machine-readable than {{*}}-formatting) *
**********************************************************************************************************************/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so: */
.hlist dt:not(:last-child)::after {
content: ":\20";
}
.hlist dd:not(:last-child)::after,
.hlist li:not(:last-child)::after {
/* "space, Middle Dot, space"
We use unicode numbers instead of the raw characters due to a Firefox encoding bug on unicode characters.
The space is also encoded because raw spaces combined with a unicode number strips the spaces under some conditions such as single-line lists */
/* content: "\20\00B7\20"; font-weight: bold; */
/* "space • space"
There may (and likely) be an extra whitespace between <li>s,
therefore we have to use a space character as last character of this sequence.
By this way, the last space and the next whitespce will collapse as a single space,
to make the whitespace on both sides of the middle dot the same width.
*/
content: "\20\A0\2022\A0\20";
font-weight: inherit;
}
/* Add parentheses around nested lists */
.hlist dd ol::before,
.hlist dd ul::before,
.hlist dd dl::before,
.hlist dt ol::before,
.hlist dt ul::before,
.hlist dt dl::before,
.hlist li ol::before,
.hlist li ul::before,
.hlist li dl::before {
content: "\20(";
font-weight: inherit;
}
.hlist dd ol::after,
.hlist dd ul::after,
.hlist dd dl::after,
.hlist dt ol::after,
.hlist dt ul::after,
.hlist dt dl::after,
.hlist li ol::after,
.hlist li ul::after,
.hlist li dl::after {
content: ")";
font-weight: inherit;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) ".\20";
}
/* Progressive enhancement:
* try to make the dot always follow the list item in same line
*/
.hlist :is(li,dt,dd):not(:has(:is(li,dt,dd))) {
display: inline-block;
}
/********************************************
* End semantically-correct horizontal lists *
*********************************************/
/*** Miscellaneous ***/
.responsive-image {
max-width: 100%;
height: auto;
}
.view-dark .invert-on-dark,
.view-light .invert-on-light {
filter: invert(100%);
}
.pixelated {
image-rendering: pixelated;
}
@media screen and (min-width: 720px) {
.mobileonly {
display: none;
}
}
@media screen and (max-width: 720px) {
.nomobile {
display: none;
}
}
/*** Utility classes for standard MW galleries ***/
/* it's important that spaced comes before centered in the sheet */
.gallery.gallery.gallery.spaced { /* this selector looks ridiculous but is actually part of stock Vector and therefore a necessary override */
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin-left: unset;
}
.gallery.centered {
text-align: center;
}
/**************************
* Start Modular Templates *
**************************/
/********* [[Template:Ambox]] *********/
.ambox {
--ambox-color: var(--wiki-accent-color);
border: 1px solid var(--wiki-content-border-color);
border-left: 10px solid var(--ambox-color);
border-radius: 2px;
display: flex;
align-items: center;
gap: .6em;
margin: 1em 0;
padding: 3px .6em;
background-color: var(--wiki-content-background-color--secondary);
box-shadow: 2px 2px 5px 0px #0002;
}
@media (min-width: 720px) {
.ambox {
margin-inline: 10%;
}
}
.ambox.tiny {
padding: .04rem .5em;
margin-inline: 0;
width: fit-content;
}
.ambox + .ambox {
margin-top: -.6em;
}
.ambox-content {
flex: 1;
}
.ambox-content p {
margin: .15em 0;
}
.ambox-title {
font-weight: bold;
}
/********* [[Template:Hatnote]] *********/
.hatnote {
padding: 1px 0 1px 1.6em;
margin-bottom: 0.5em;
font-style: italic;
border-top: 1px solid var(--wiki-content-border-color--secondary);
border-bottom: 1px solid var(--wiki-content-border-color--secondary);
}
.hatnote.icon {
padding-left: 0;
}
/********* [[Template:Spoiler]] *********/
.spoiler-content {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 50%, transparent);
transition: all 0.3s;
cursor: pointer;
overflow: auto;
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.spoiler-content {
background-color: var(--wiki-content-dynamic-color--secondary);
}
}
.spoiler-content > * {
pointer-events: none;
opacity: 0;
transition: all 0.3s;
}
.spoiler-content.show {
background-color: transparent;
}
.spoiler-content.show > * {
pointer-events: unset;
opacity: 1;
}
/********* [[Template:Link icon]] *********/
.link-icon {
--link-icon-line-height: 1.5em;
--link-icon-size: 1.5em;
display: inline-flex;
align-items: center;
height: var(--link-icon-line-height);
vertical-align: bottom;
}
.link-icon .regular {
align-self: center;
}
.link-icon .regular a {
display: flex;
}
.link-icon .regular img {
height: var(--link-icon-size);
max-width: var(--link-icon-size);
}
.link-icon .fallback {
outline: 1px solid var(--wiki-content-text-color);
border-radius: 50%;
text-align: center;
width: var(--link-icon-size);
line-height: var(--link-icon-size);
}
.link-icon.notext,
.link-icon.notext .fallback {
display: inline-block;
}
/********* [[Template:Quote]] *********/
.quote {
background: var(--wiki-content-background-color--secondary);
border-radius: 5px;
border: 2px solid var(--wiki-content-border-color);
margin: .5em 0;
padding: .5em;
overflow-y: hidden;
}
.quote .block {
display: block;
}
.quote .title {
font-size: large;
font-weight: bold;
}
.quote .content {
font-style: italic;
}
.quote .author {
font-weight: bold;
text-align: end;
}
.quote .marks-wrapper {
display: flex;
gap: 5px;
}
.quote .marks-wrapper::before,
.quote .marks-wrapper::after {
font-size: 100px;
line-height: 0px;
}
.quote .marks-wrapper::before {
content: "\201C";
margin-top: 40px;
}
.quote .marks-wrapper::after {
content: "\201D";
align-self: end;
margin-bottom: -10px;
}
.client-js .mw-charinsert-item {
display: none;
}
/************************
* End Modular Templates *
*************************/
/*****************************
* Used by [[Template:Color]] *
******************************/
.color__splotch {
display: inline-block;
height: 1em;
width: 1em;
box-sizing: border-box;
vertical-align: text-top;
border-radius: 50%;
border: 1px solid var(--wiki-content-text-color);
}
/*********************
* End Template:Color *
**********************/
/*********************************
* Used by [[Template:TOC limit]] *
**********************************/
.toclimit-2 .toclevel-1 ul,
.toclimit-3 .toclevel-2 ul,
.toclimit-4 .toclevel-3 ul,
.toclimit-5 .toclevel-4 ul,
.toclimit-6 .toclevel-5 ul,
.toclimit-7 .toclevel-6 ul {
display: none;
}
/*************************
* End Template:TOC limit *
**************************/
/*********************************
* Used by [[Template:TOC right]] *
**********************************/
@media all and (min-width: 720px) {
.tocright {
float: right;
clear: right;
margin: 0 0 0.5em 1em;
}
}
/*************************
* End Template:TOC right *
**************************/
40bfba1f9ff64946e8ca2054b3ba281f00f40f54
MediaWiki:Theme-definitions
8
236
260
2025-08-20T01:24:56Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
* light[bundled|kind=light]
* dark[bundled|kind=dark]
05cdfdf87ea42919cc6ea267d3972cc06847ed60
MediaWiki:Gadgets/purge/main.js
8
237
261
2025-08-20T01:24:57Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
$.when( $.ready )
.then(function(){
if ( document.getElementById( 'ca-cargo-purge' )){ return; } // disable if Cargo has already added a purge button
if ( mw.config.get( 'wgNamespaceNumber' ) === -1 ) { return; } // disable on special pages
var url = new URL(window.location.href);
url.searchParams.set('action', 'purge');
var button = mw.util.addPortletLink('p-cactions', url.href, mw.msg('cargo-purgecache'), 'ca-gadget-purgecache', mw.msg('action-purge'), '1');
button.addEventListener('click', (function(event) {
event.preventDefault();
var api = new mw.Api();
api.post({
action: 'purge',
titles: mw.config.get('wgPageName'),
forcerecursivelinkupdate: true
}).then(function() {
window.location.reload(true);
}).fail(function(code) {
mw.notify(mw.msg('cargo-purgecache-failed')+" "+code);
});
}));
});
5d10082771b97fa1ba479534a973769321d887dc
MediaWiki:Gadgets/userProfile/main.js
8
238
262
2025-08-20T01:24:58Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
// User profile
// <nowiki>
mw.loader.using( [ 'mediawiki.util', 'mediawiki.api' ] ).done( function() {
var config = mw.config.get( [
'wgRelevantUserName',
'wgNamespaceNumber',
'wgUserLanguage',
'wgArticleId',
'wgAction',
'wgTitle'
] );
var username = config.wgRelevantUserName;
if ( !username || window.loadedHorseUserProfile ) return;
window.loadedHorseUserProfile = true;
if ( config.wgNamespaceNumber !== -1 && config.wgTitle.includes('/') ) return;
var lang = mw.language.bcp47(config.wgUserLanguage);
var dateOptions = {
year: "numeric",
month: "short",
day: "numeric",
hour: "2-digit",
minute: "2-digit",
timeZone: "UTC",
timeZoneName: "short"
};
var api = new mw.Api();
if ( mw.util.isIPAddress(username) ) api.get( {
action: 'query',
list: ['usercontribs', 'blocks'],
ucuser: username,
ucprop: [],
uclimit: 'max',
bkip: username,
bkprop: ['user', 'by', 'timestamp', 'expiry', 'flags', 'reason', 'restrictions'],
bklimit: 1,
formatversion: 2
} ).done( function(data) {
var editcount = data.query.usercontribs.length;
if ( data.continue && data.continue.uccontinue ) editcount = data.limits.usercontribs+'+';
var user = {
groups: ['*'],
editcount: editcount
};
formatProfile(user, data.query.blocks[0]);
} );
else api.get( {
action: 'query',
list: ['users', 'blocks'],
ususers: username,
usprop: ['groups', 'editcount', 'registration', 'emailable'],
bkusers: username,
bkprop: ['user', 'by', 'timestamp', 'expiry', 'flags', 'reason', 'restrictions'],
bklimit: 1,
formatversion: 2
} ).done( function(data) {
formatProfile(data.query.users[0], data.query.blocks[0]);
} );
if ( window.loadedHorseUserProfileContribs ) return;
window.loadedHorseUserProfileContribs = true;
if ( config.wgNamespaceNumber === 2 && !config.wgArticleId && config.wgAction === 'view' ) {
mw.loader.using( [ 'mediawiki.pager.styles', 'mediawiki.special.changeslist' ] ).then( function() {
var text = '== [[Special:Contributions/' + username + '|{{int:contributions-title|' + username + '}}]] ==\n{{Special:Contributions/' + username + '|limit=20}}';
new mw.Api().parse( text, {
title: 'User:' + config.wgTitle,
wrapoutputclass: 'horse-userprofile-contribs',
disableeditsection: true,
disablelimitreport: true,
uselang: config.wgUserLanguage
} ).done( function(parsedText) {
mw.hook( 'wikipage.content' ).fire(
$( parsedText ).appendTo('#mw-content-text')
);
} );
} );
}
function formatProfile(user, block) {
user.groups.splice(user.groups.indexOf('*'), 1);
var text = '<div class="horse-userprofile-info">';
if ( user.groups.length ) {
var groupList = user.groups.map( function(group) {
var grouppage = '{{MediaWiki:grouppage-'+group+'}}';
return [
'{{#ifexist: '+grouppage+' | [['+grouppage+'|{{int:group-'+group+'}}]] | {{int:group-'+group+'}} }}',
'{{#ifexist: '+grouppage+' | [['+grouppage+'|{{int:group-'+group+'-member|'+username+'}}]] | {{int:group-'+group+'-member|'+username+'}} }}'
];
} ).reduce( function(prev, cur) {
prev[0].push(cur[0]);
prev[1].push(cur[1]);
return prev;
}, [[], []] );
text += '\n\n<span>{{int:prefs-memberingroups|'+user.groups.length+'|'+username+'}}</span>\t<span>{{int:prefs-memberingroups-type|'+mw.language.listToText(groupList[0])+'|'+mw.language.listToText(groupList[1])+'}}</span>';
if (mw.config.get('wgUserGroups').some(item => ['advocate', 'staff'].includes(item))) { //return true if their usergroups contain advocate or staff
text += '<br/>([[Special:UserRights/' + username + '|{{int:tool-link-userrights|' + username + '}}]])'
}
}
text += '\n\n<span>{{int:prefs-edits}}</span>\t<span>[[Special:Contribs/'+username+'|'+mw.language.convertNumber(user.editcount)+']]</span>';
if ( user.registration ) text += '\n\n<span>{{int:prefs-registration}}</span>\t<span>'+mw.language.convertNumber(new Date(user.registration).toLocaleString(lang, dateOptions))+'</span>';
if ( user.userid && !user.emailable ) text += '\n\n<span>{{int:nowikiemailtext|'+username+'}}</span>';
text += '\n\n</div>';
if ( block && !$('.mw-warning-with-logexcerpt .mw-logevent-loglines > .mw-logline-block').length ) {
var notice = 'sp-contributions-blocked-notice';
if ( mw.util.isIPAddress(block.user, true) ) notice += '-anon';
var logentry = 'logentry-block-block';
var partialBlock = [];
if ( block.partial ) {
notice += '-partial';
logentry = 'logentry-partialblock-block';
if ( block.restrictions.pages ) {
var blockpages = block.restrictions.pages.map( function(page) {
return '[['+page.title+']]';
} );
partialBlock.push('{{int:logentry-partialblock-block-page|'+blockpages.length+'|'+mw.language.listToText(blockpages)+'}}');
}
if ( block.restrictions.namespaces ) {
var blocknamespaces = block.restrictions.namespaces.map( function(namespace) {
if ( !namespace ) return '[[Special:AllPages|{{int:blanknamespace}}]]';
return '[[Special:AllPages/{{ns:'+namespace+'}}:|{{ns:'+namespace+'}}]]';
} );
partialBlock.push('{{int:logentry-partialblock-block-ns|'+blocknamespaces.length+'|'+mw.language.listToText(blocknamespaces)+'}}');
}
if ( block.restrictions.actions ) {
var blockactions = block.restrictions.actions.map( function(action) {
return '{{int:ipb-action-'+action+'}}';
} );
partialBlock.push('{{int:logentry-partialblock-block-action|'+blockactions.length+'|'+mw.language.listToText(blockactions)+'}}');
}
if ( !partialBlock.length ) logentry = 'logentry-non-editing-block-block';
}
var blockDate = new Date(block.timestamp);
var blockexpiry = '{{int:infiniteblock}}';
if ( !['infinite', 'indefinite', 'infinity', 'never'].includes(block.expiry) ) {
var expiry = new Date(block.expiry.replace( /(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2,3})/, '$1-$2-$3T$4:$5:$6Z' ));
var duration = expiry - blockDate;
var blockDuration = [];
var factor = 1000;
if ( duration % factor === 0 ) blockDuration = ['duration-seconds', Math.floor(duration / factor)];
factor *= 60;
if ( duration % factor === 0 ) blockDuration = ['duration-minutes', Math.floor(duration / factor)];
factor *= 60;
if ( duration % factor === 0 ) blockDuration = ['duration-hours', Math.floor(duration / factor)];
factor *= 24;
if ( duration % factor === 0 ) blockDuration = ['duration-days', Math.floor(duration / factor)];
if ( duration % (factor*7) === 0 ) blockDuration = ['duration-weeks', Math.floor(duration / (factor*7))];
if ( duration % (factor*30) === 0 ) blockDuration = ['months', Math.floor(duration / (factor*30))];
factor *= 365;
if ( duration % factor === 0 ) blockDuration = ['duration-years', Math.floor(duration / factor)];
if ( duration % (factor*10) === 0 ) blockDuration = ['duration-decades', Math.floor(duration / (factor*10))];
if ( duration % (factor*100) === 0 ) blockDuration = ['duration-centuries', Math.floor(duration / (factor*100))];
if ( duration % (factor*1000) === 0 ) blockDuration = ['duration-millennia', Math.floor(duration / (factor*1000))];
if ( blockDuration.length < 2 || blockDuration[1] > 1000 ) blockexpiry = mw.language.convertNumber(expiry.toLocaleString(lang, dateOptions));
else blockexpiry = '{{int:'+blockDuration.join('|')+'}}';
}
var blockflags = '';
var blockflaglist = [];
if ( block.anononly ) blockflaglist.push('{{int:block-log-flags-anononly}}');
if ( block.nocreate ) blockflaglist.push('{{int:block-log-flags-nocreate}}');
if ( !block.autoblock && !mw.util.isIPAddress(block.user, true) ) blockflaglist.push('{{int:block-log-flags-noautoblock}}');
if ( !block.allowusertalk ) blockflaglist.push('{{int:block-log-flags-nousertalk}}');
if ( block.noemail ) blockflaglist.push('{{int:block-log-flags-noemail}}');
if ( block.hidden ) blockflaglist.push('{{int:block-log-flags-hiddenname}}');
if ( blockflaglist.length ) blockflags = '{{int:parentheses|'+blockflaglist.join(mw.msg('comma-separator'))+'}}';
var blockreason = ' <span class="comment">{{int:parentheses|'+block.reason+'}}</span>';
if ( !block.reason ) blockreason = '';
text += '<div class="horse-userprofile-block cdx-message cdx-message--block cdx-message--warning mw-warning-with-logexcerpt"><span class="cdx-message__icon"></span><div class="cdx-message__content">\n{{int:'+notice+'|'+username+'}}\n';
text += '<ul class="mw-logevent-loglines"><li class="mw-logline-block">'+mw.language.convertNumber(blockDate.toLocaleString(lang, dateOptions))+' {{int:'+logentry+'|[[User:'+block.by+'|'+block.by+']] <span class="mw-usertoollinks mw-changeslist-links"><span>[[User talk:'+block.by+'|{{int:talkpagelinktext}}]]</span> <span>[[Special:Contribs/'+block.by+'|{{int:contribslink}}]]</span></span>|'+block.by;
if ( mw.util.isIPAddress(block.user, true) ) text += '|[[Special:Contribs/'+block.user+'|'+block.user+']] <span class="mw-usertoollinks mw-changeslist-links"><span>[[User talk:'+block.user+'|{{int:talkpagelinktext}}]]</span></span>';
else text += '|[[User:'+block.user+'|'+block.user+']] <span class="mw-usertoollinks mw-changeslist-links"><span>[[User talk:'+block.user+'|{{int:talkpagelinktext}}]]</span> <span>[[Special:Contribs/'+block.user+'|{{int:contribslink}}]]</span></span>';
text += '|'+block.user+'|'+blockexpiry+'|'+blockflags+'|'+mw.language.listToText(partialBlock)+'}}'+blockreason+'</li></ul></div></div>';
}
api.parse( '<div class="cdx-message__content">' + text + '</div>', {
disablelimitreport: true,
wrapoutputclass: 'horse-userprofile mw-message-box cdx-message mw-content-'+($('#mw-content-subtitle').attr('dir')||'ltr'),
uselang: config.wgUserLanguage
} ).done( function(parsedText) {
parsedText = parsedText.replace( /\u29FCgroup-([^\u29FC\u29FD]+?)(?:-member)?\u29FD/g, '$1' );
mw.hook( 'wikipage.content' ).fire(
$( parsedText ).appendTo('#contentSub')
);
} );
}
} );
// </nowiki>
a86531394e21271ad91869b48f3634f341b1bd79
MediaWiki:Gadgets/userProfile/main.css
8
239
263
2025-08-20T01:24:58Z
ARTIFICER
564804
Importing default loadout
css
text/css
#contentSub > * + .horse-userprofile {
margin-top: 1em;
}
.horse-userprofile {
font-size: 120%;
color: var(--wiki-content-text-color);
border: 2px solid var(--wiki-content-border-color);
padding: 6px 12px;
}
.horse-userprofile-info span:first-of-type {
font-weight: bold;
}
1729445bb17e2974426befaf9bd441ab4bf189c5
MediaWiki:Gadgets/uploadMultipleFiles/main.js
8
240
264
2025-08-20T01:24:59Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
/* Modified version of https://dev.fandom.com/wiki/UploadMultipleFiles
* from https://terraria.wiki.gg/wiki/MediaWiki:Gadget-uploadMultipleFiles.js */
$.when( mw.loader.using( ['site', 'mediawiki.util', 'mediawiki.api', 'mediawiki.jqueryMsg'] ), $.ready )
.then( () => new mw.Api().loadMessagesIfMissing([
'gadget-uploadMultipleFiles-multiupload',
'gadget-uploadMultipleFiles-yes',
'gadget-uploadMultipleFiles-no',
'gadget-uploadMultipleFiles-sourcefiles',
'gadget-uploadMultipleFiles-categoryname',
'gadget-uploadMultipleFiles-categorynamehint',
'gadget-uploadMultipleFiles-categorynamespace',
'gadget-uploadMultipleFiles-uploadfiles',
'gadget-uploadMultipleFiles-nofiles',
'gadget-uploadMultipleFiles-nolicense',
'gadget-uploadMultipleFiles-summary',
'gadget-uploadMultipleFiles-license',
'gadget-uploadMultipleFiles-categories',
'gadget-uploadMultipleFiles-uploading',
'gadget-uploadMultipleFiles-uploaded',
'gadget-uploadMultipleFiles-failed',
'gadget-uploadMultipleFiles-done',
'gadget-uploadMultipleFiles-ratelimited',
]) )
.then(function(){
if (mw.config.get("wgCanonicalSpecialPageName") !== "Upload"){ return; }
if (window.__wgg_UploadMultipleFiles_IsLoaded) { return; }
window.__wgg_UploadMultipleFiles_IsLoaded = true;
const getUploadDescription = function() {
var sections = [];
var summary = $("#wpUploadDescription").val();
var licenseDisplayName = $("#wpLicense option:selected").val();
var categoryName = $("#multiFileCategory").val();
if (summary !== ""){
sections.push(summary);
}
if (licenseDisplayName !== "") {
var licenseTemplateText = $("#wpLicense option:selected").prop("title");
sections.push("== " + mw.msg("gadget-uploadMultipleFiles-license") + " ==\n" + licenseTemplateText);
}
if (categoryName !== "")
sections.push("[[" + mw.msg("gadget-uploadMultipleFiles-categorynamespace") + ":" + categoryName + "]]");
return sections.join("\n\n");
};
const getWatchlistPreference = function() {
if ($("#wpWatchthis").is(":checked")) {
return "watch";
} else {
return "nochange";
}
};
$("#wpUploadFile").parent().parent().addClass("regularFileSelect");
$("tr.regularFileSelect").before(
$("<tr></tr>").append(
$('<td class="mw-label"></td>').msg("gadget-uploadMultipleFiles-multiupload"),
$('<td class="mw-input"></td>').append(
$("<label></label>").msg("gadget-uploadMultipleFiles-yes").prepend('<input type="radio" name="multipleFiles" value="yes" /> '),
' ',
$("<label></label>").msg("gadget-uploadMultipleFiles-no" ).prepend('<input type="radio" name="multipleFiles" value="no" checked/> '),
)
)
).after(
$('<tr class="multipleFileSelect" style="display:none;"></tr>').append(
$('<td class="mw-label"></td>').msg("gadget-uploadMultipleFiles-sourcefiles"),
$('<td class="mw-input"></td>').append('<input type="file" id="multiupload" multiple />')
)
);
$("input[name='wpUpload']").addClass("regularFileSelect");
$("#wpDestFile").parent().parent().addClass("regularFileSelect");
$("#wpIgnoreWarning").parent().parent().addClass("regularFileSelect");
// Append "category name" textbox to multiupload section
$("#mw-upload-form #mw-htmlform-description tbody").append(
$('<tr class="mw-htmlform-field-HTMLTextField multipleFileSelect" style="display:none;"></tr>').append(
$('<td class="mw-label"></td>').append('<label for="multiFileCategory"><abbr title="' + mw.msg("gadget-uploadMultipleFiles-categorynamehint") + '">' + mw.msg("gadget-uploadMultipleFiles-categoryname") + '</abbr></label>'),
$('<td class="mw-input"></td>').append('<input id="multiFileCategory" name="multiFileCategory" size="60">')
)
);
$("input[name='wpUpload']").after('<input type="button" value="' + mw.msg("gadget-uploadMultipleFiles-uploadfiles") + '" class="multipleFileSelect" style="display:none;" id="multiFileSubmit" />');
$("input[name='multipleFiles']").change(function() {
if (this.value === 'yes') {
$(".regularFileSelect").hide();
$(".multipleFileSelect").show();
} else {
$(".regularFileSelect").show();
$(".multipleFileSelect").hide();
}
});
$("#multiFileSubmit").click(function() {
var files = $("#multiupload")[0].files;
// Cancel upload if no files are selected
if (files.length === 0) {
alert(mw.msg("gadget-uploadMultipleFiles-nofiles"));
return false;
}
// Cancel upload if no license is selected
if ($("#wpLicense option:selected").val() === "" && !mw.config.get("UMFBypassLicenseCheck")) {
alert(mw.msg("gadget-uploadMultipleFiles-nolicense"));
return false;
}
// Description is summary + license + category
var description = getUploadDescription();
var watch = getWatchlistPreference();
$("#firstHeading").msg("gadget-uploadMultipleFiles-uploading");
$("#mw-content-text").html("<h3>" + mw.msg("gadget-uploadMultipleFiles-uploaded") + "</h3><ul></ul><div style='display:none;' id='multiUploadFailed'><h3>" + mw.msg("gadget-uploadMultipleFiles-failed") + "</h3><ul></ul></div>");
var currentFileIdx = 0;
var uploadCurrentFile;
uploadCurrentFile = function() {
if (currentFileIdx > files.length) {
$("#mw-content-text").append($("<h3></h3>").msg("gadget-uploadMultipleFiles-done"));
return;
}
if (files[currentFileIdx] === undefined) {
currentFileIdx++;
uploadCurrentFile();
return;
}
fd = new FormData();
fd.append("action", "upload");
fd.append("token", mw.user.tokens.get("csrfToken"));
fd.append("filename", files[currentFileIdx].name);
fd.append("file", files[currentFileIdx]);
fd.append("text", description);
fd.append("watchlist", watch);
fd.append("ignorewarnings", 1);
fd.append("format", "json");
const $output = $("#mw-content-text > ul");
const $failed = $("#multiUploadFailed");
const $failedOutput = $('#multiUploadFailed ul');
$.ajax({
url: mw.util.wikiScript("api"),
method: "POST",
data: fd,
cache: false,
contentType: false,
processData: false,
type: "POST"
}).done(function(d) {
if (d.error == undefined) {
$output.append('<li><a href="' + d.upload.imageinfo.descriptionurl + '" target="_blank">' + d.upload.filename + '</a></li>');
}
// specific catch for ratelimiting
else if(d.error.code === "ratelimited") {
timer = 60;
console.log(mw.msg('gadget-uploadMultipleFiles-ratelimited', timer));
$message = $('<li class="multiUploadActive"></li>').msg('gadget-uploadMultipleFiles-ratelimited', $('<span id="rateLimitCounter">' + timer + '</span>'));
$output.append($message);
var countdown = setInterval(function(){
// count the timer down, and remove at 0
timer -= 1;
document.getElementById('rateLimitCounter').textContent = timer;
if (timer <= 0) {
$message.remove()
clearInterval(countdown);
}
}, 1000);
setTimeout(function(){
// redundant clearing of the interval and message in case of race conditions
clearInterval(countdown);
$message.remove();
uploadCurrentFile();
}, timer * 1000);
return;
}
// generic fallback
else {
$failedOutput.append('<li>' + files[currentFileIdx].name + ': ' + d.error.info + '</li>');
$failed.show();
}
currentFileIdx++;
uploadCurrentFile();
}).fail(function() {
$failedOutput.append('<li>' + files[currentFileIdx].name + '</li>');
$failed.show();
currentFileIdx++;
uploadCurrentFile();
});
};
uploadCurrentFile();
});
});
f47e56dc31399578758f15aafbdf732564a80bd3
MediaWiki:Licenses
8
241
265
2025-08-20T01:25:00Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
*Game content
** License|game|This contains content from the game or its official media
*Commonly used
** License|fairuse|This will be used in a way that qualifies as "fair use" under US law
** License|CC0|This file is licensed under the CC0 1.0 License
** License|CC-BY-NC-ND|This is licensed under the Creative Commons Attribution-NonCommercial-NoDerivs 3.0 License
** License|CC-BY-NC-SA|This is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License
** License|CC-BY-NC|This is licensed under the Creative Commons Attribution-NonCommercial 3.0 License
** License|CC-BY-ND|This is licensed under the Creative Commons Attribution-NoDerivs 3.0 License
** License|CC-BY-SA|This is licensed under the Creative Commons Attribution-ShareAlike 3.0 License
** License|permission|The copyright holder gave permission to use this work only in wiki.gg articles
** License|CC-BY|This is licensed under the Creative Commons Attribution 3.0 License
** License|CC-PD|This is in the public domain
** License|CC-SRR|This is licensed under the Creative Commons Some Rights Reserved License
*Unsure or unknown
** License|nolicense|I don't know the license
80cf31331a258a3fc3651f6d5961fbb5c1822cee
MediaWiki:Copyright
8
242
266
2025-08-20T01:25:01Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{int:wikigg-copyright|CC BY-SA 4.0|$1}}
999f12b472b0177c515e14cda21d5e4ddc0603e1
MediaWiki:Mainpage
8
243
267
2025-08-20T01:25:02Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
{{SITENAME}}
3879910e8b355a24373fd09ccc909145b2639907
MediaWiki:Apioutput.css
8
244
268
2025-08-20T01:25:02Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* All CSS here is applied on api.php pages */
@media (prefers-color-scheme: dark) {
body {
background-color:#20211f;
border-color: #7b7261;
color: #f6ecdb;
}
h1, h2, h3, h4, h5, h6 {
color: rgb(234, 224, 207);
border-color: rgb(83, 84, 81);
}
.mw-highlight .s2 {
color: rgb(206, 99, 91);
}
a {
color: rgb(133, 180, 221);
}
a:visited {
color: rgb(141, 127, 218);
}
pre, code, .mw-code {
background-color: rgb(34, 35, 33);
color: rgb(234, 224, 207);
border-color: rgb(63, 64, 62);
}
}
c95cf2c22c12d821f22b745f2aa78d4f6f711500
MediaWiki:Gadgets/hoverShowSpoilers/main.css
8
245
269
2025-08-20T01:25:03Z
ARTIFICER
564804
Importing default loadout
css
text/css
.spoiler-content:hover > * {
pointer-events:unset;
opacity: 1;
}
.spoiler-content:hover {
background-color: transparent;
}
1c73aafcb749d7e0e9107c1045310d2af70aae7e
MediaWiki:Common.css/doc
8
246
270
2025-08-20T01:25:03Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<div class="mw-parser-output" id="dl-variable-doc"><!-- hide this in your global.css if you're familiar with how default loadout works and this documentation is just in your way -->
<h2>Documentation</h2>
This wiki is using the theming template from the [[dlw:|default loadout]]. This template is intended to minimize the work required to create a custom colored version of the standard [[mw:Skin:Vector|Vector]] skin, while maximizing the various nooks and crannies that those colors reach, all while keeping everything legible and matching.
Please be aware of the [[support:Customization policy|customization policy]] when modifying the theme.
<h3>Themes</h3>
The [[support:Theme Toggle|Theme Toggle]] extension is installed, and allows multiple themes to be used. In the actual stylesheet below this documentation, you'll find two huge rules at the top, each containing lots of [https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties CSS color variables]. They look like this:
<syntaxhighlight lang=css>
:root,
/* Begin light styles, delete from here to "end light styles" if you don't want your wiki to support any light themes (remove from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=light, */
/* individual themes are prefixed with .theme- instead */
.view-light {
/**********************
* Probably edit these * [ LIGHT VIEW ]
***********************/
--wiki-body-background-color: #F6F6F6;
--wiki-body-background-image: url(filepath://Site-background.jpg);
/* and so on */
}
.view-dark {
/**********************
* Probably edit these * [ DARK VIEW ]
***********************/
--wiki-body-background-color: #171717;
--wiki-body-background-image: url(filepath://Site-background-dark.jpg);
/* and so on */
}
</syntaxhighlight>
These are the standard light and dark themes, defined in [[Mediawiki:Theme-definitions]]. '''Important''': if you want your wiki to only support a single theme, edit that page and remove the line you don't want (don't remove both). The <code>:root</code> selector is a fallback, meaning that in case something happens and Theme Toggle fails to work, the following theme will still mostly work. If you have multiple themes, you can move the <code>:root</code> rule to whichever you'd consider the "default" theme.
<h3>Non-color variables</h3>
{| class="wikitable"
! Variable name !! Notes
|-
| --wiki-body-background-image
| This is the image path to the wiki's background image. Usually this is uploaded to File:Site-background.jpg, File:Site-background-light.jpg, and/or File:Site-background-dark.jpg. While there's not a hard file size limit, it is recommended that this not exceed 250 KB. File size can be reduced by resizing (anything over 2560x1440p is excessive), converting to a jpg, and compressed using sites like [https://tinypng.com TinyPNG].
|-
| --wiki-body-background-position
| The [https://developer.mozilla.org/en-US/docs/Web/CSS/background-position background-position] of the background image. Usually this is set to <code>top center</code>.
|-
| --wiki-body-background-size
| The [https://developer.mozilla.org/en-US/docs/Web/CSS/background-size background-size] of the background image. Usually this is set to <code>cover</code>.
|-
| --wiki-body-background-repeat
| The [https://developer.mozilla.org/en-US/docs/Web/CSS/background-repeat background-repeat] of the background image. Usually this is set to <code>no-repeat</code>.
|-
| --wiki-body-background-attachment
| The [https://developer.mozilla.org/en-US/docs/Web/CSS/background-attachment background-attachment] of the background image. Usually this is set to <code>fixed</code>.
|-
| --wiki-body-font-family
| The font family of most of the wiki, such as the sidebar, navigation, and content text. Usually this is sans-serif. If modifying this, use a simple font that is easy to read. See <code>--wiki-heading-font-family</code> if you want to incorporate a more decorative font into the theme.
|-
| --wiki-heading-font-family
| The font family of headings, such as the page title and section headings. This font is usually displayed in a larger size, so it's safer to use a more decorative font than <code>--wiki-body-font-family</code>, but still try to keep it legible.
|-
| --wiki-sidebar-heading-font-family
| The font family of sidebar headings. In contrast to <code>--wiki-heading-font-family</code>, this is usually displayed in a smaller size, so keep it simple and easy to read.
|-
| --wiki-sidebar-border-radius
| The [https://developer.mozilla.org/en-US/docs/Web/CSS/border-radius border-radius] of the sidebar. If <code>--wiki-sidebar-portal-spacing</code> is set to 0, then only the top and bottom corners of the sidebar as a whole will be affected, otherwise every portal will have all its corners affected. Units must be specified even if this is set to 0.
|-
| --wiki-sidebar-portal-spacing
| The space between each portal in the sidebar. Units must be specified even if this is set to 0.
|-
| --wiki-content-border-width
| The thickness of the border around the content area.
|-
| --wiki-sidebar-border-width
| The thickness of the border around the sidebar portals.
|-
| --wiki-content-background-opacity
| The opacity of the main content area, to let the wiki's background image show through. Please keep this high, usually above 90%, or it can make reading text difficult.
|-
| --wiki-sidebar-background-opacity
| The background opacity of the sidebar. Usually this inherits <code>--wiki-content-background-opacity</code>.
|-
| --wiki-icon-general-filter
| A filter applied to many icons to make them visible on dark themes. Usually this is just <code>invert(100%)</code> on dark themes and blank on light themes.
|-
| --wiki-icon-to-link-filter
| A filter that converts many icons into the same color as <code>--wiki-content-link-color</code>. This can be generated by plugging that into https://mrpie5.gitlab.io/css-filter-generator/.
|}
<h3>List of all colors with contrast checking</h3>
The table below shows all the colors currently in use, as well as notes on how to use them. The last column shows which colors are expected to show up as text against other colors. With the exception of <code>--wiki-content-text-mix-color-95</code>, all text in the last column should be ''clearly'' legible. If it is not, you may need to adjust one of the referenced colors in your color palette.
Keep in mind that changes to the opacity variables in the section above will cause the content and sidebar background colors to mix with the body background color/image, so the contrasts below may not be perfectly accurate.
{| class="wikitable"
! Variable name !! Color !! style="width: 40em;" | Notes !! Test contrast against these variables
|-
| --wiki-body-background-color
| style="background-color:var(--wiki-body-background-color);" |
| The background color behind the background image. This usually only shows up if the background image doesn't load, doesn't fill the screen, or has some transparency. This color should be similar to the overall color of the background image, or the top-left corner if it is made up of many different colors. In the former case, https://matkl.github.io/average-color/ is helpful.
| style="background-color:var(--wiki-body-background-color);" |
<span style="color:var(--wiki-body-dynamic-color);">--wiki-body-dynamic-color</span><br/>
<span style="color:var(--wiki-body-dynamic-color--secondary);">--wiki-body-dynamic-color--secondary</span><br/>
|-
| --wiki-body-dynamic-color
| style="background-color:var(--wiki-body-dynamic-color);" |
| This is expected to contrast sharply with the body-background-color, for cases when text needs to be displayed against it. Usually this is {{color|#000}} on light themes and {{color|#fff}} on dark themes.
| style="background-color:var(--wiki-body-dynamic-color);" |
<span style="color:var(--wiki-body-background-color)">--wiki-body-background-color</span><br/>
<span style="color:var(--wiki-body-dynamic-color--inverted);">--wiki-body-dynamic-color--inverted</span><br/>
<span style="color:var(--wiki-body-dynamic-color--secondary--inverted);">--wiki-body-dynamic-color--secondary--inverted</span><br/>
|-
| --wiki-body-dynamic-color--inverted
| style="background-color:var(--wiki-body-dynamic-color--inverted);" |
| The inverse of <code>--wiki-body-dynamic-color</code>. This should optimally have almost no contrast with the body-background-color.
| style="background-color:var(--wiki-body-dynamic-color--inverted);" |
<span style="color:var(--wiki-body-dynamic-color);">--wiki-body-dynamic-color</span><br/>
<span style="color:var(--wiki-body-dynamic-color--secondary);">--wiki-body-dynamic-color--secondary</span><br/>
|-
| --wiki-body-dynamic-color--secondary
| style="background-color:var(--wiki-body-dynamic-color--secondary);" |
| A slightly different version of body-dynamic-color. Usually this is {{color|#333}} on light themes and {{color|#ccc}} on dark themes.
| style="background-color:var(--wiki-body-dynamic-color--secondary);" |
<span style="color:var(--wiki-body-background-color)">--wiki-body-background-color</span><br/>
<span style="color:var(--wiki-body-dynamic-color--inverted);">--wiki-body-dynamic-color--inverted</span><br/>
<span style="color:var(--wiki-body-dynamic-color--secondary--inverted);">--wiki-body-dynamic-color--secondary--inverted</span><br/>
|-
| --wiki-body-dynamic-color--secondary--inverted
| style="background-color:var(--wiki-body-dynamic-color--secondary--inverted);" |
| The inverse of <code>--wiki-body-dynamic-color--secondary</code>.
| style="background-color:var(--wiki-body-dynamic-color--secondary--inverted);" |
<span style="color:var(--wiki-body-dynamic-color);">--wiki-body-dynamic-color</span><br/>
<span style="color:var(--wiki-body-dynamic-color--secondary);">--wiki-body-dynamic-color--secondary</span><br/>
|-
| --wiki-content-background-color
| style="background-color:var(--wiki-content-background-color);" |
| The background color of the main content area.
| style="background-color:var(--wiki-content-background-color);" |
<span style="color:var(--wiki-content-text-color)">--wiki-content-text-color</span><br/>
<span style="color:var(--wiki-content-link-color)">--wiki-content-link-color</span><br/>
<span style="color:var(--wiki-content-link-color--visited)">--wiki-content-link-color--visited</span><br/>
<span style="color:var(--wiki-content-link-color--hover)">--wiki-content-link-color--hover</span><br/>
<span style="color:var(--wiki-content-redlink-color)">--wiki-content-redlink-color</span><br/>
<span style="color:var(--wiki-content-text-mix-color)">--wiki-content-text-mix-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color)">--wiki-content-dynamic-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color--secondary)">--wiki-content-dynamic-color--secondary</span><br/>
<span style="color:var(--wiki-content-heading-color)">--wiki-content-heading-color</span><br/>
<span style="color:var(--wiki-accent-color)">--wiki-accent-color</span><br/>
<span style="color:var(--wiki-neutral-color)">--wiki-neutral-color</span><br/>
<span style="color:var(--wiki-success-color)">--wiki-success-color</span><br/>
<span style="color:var(--wiki-alert-color)">--wiki-alert-color</span><br/>
|-
| --wiki-content-background-color--secondary
| style="background-color:var(--wiki-content-background-color--secondary);" |
| A secondary content background to highlight certain things. Usually this is <code>--wiki-content-background-color</code> with saturation and/or value reduced or increased by about 10%, but you're free to make it whatever you want provided the contrast checks to the right still pass.
| style="background-color:var(--wiki-content-background-color--secondary);" |
<span style="color:var(--wiki-content-text-color)">--wiki-content-text-color</span><br/>
<span style="color:var(--wiki-content-link-color)">--wiki-content-link-color</span><br/>
<span style="color:var(--wiki-content-link-color--visited)">--wiki-content-link-color--visited</span><br/>
<span style="color:var(--wiki-content-link-color--hover)">--wiki-content-link-color--hover</span><br/>
<span style="color:var(--wiki-content-redlink-color)">--wiki-content-redlink-color</span><br/>
<span style="color:var(--wiki-content-text-mix-color)">--wiki-content-text-mix-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color)">--wiki-content-dynamic-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color--secondary)">--wiki-content-dynamic-color--secondary</span><br/>
<span style="color:var(--wiki-content-heading-color)">--wiki-content-heading-color</span><br/>
<span style="color:var(--wiki-accent-color)">--wiki-accent-color</span><br/>
<span style="color:var(--wiki-neutral-color)">--wiki-neutral-color</span><br/>
<span style="color:var(--wiki-success-color)">--wiki-success-color</span><br/>
<span style="color:var(--wiki-alert-color)">--wiki-alert-color</span><br/>
|-
| --wiki-content-border-color
| style="background-color:var(--wiki-content-border-color);" |
| Border color for the main content area and elements within it.
| N/A
|-
| --wiki-content-border-color--secondary
| style="background-color:var(--wiki-content-border-color--secondary);" |
| A secondary content border color for elements that do not need to stand out as much. Usually this is <code>--wiki-content-border-color</code> with 50% transparency, but it can be adjusted or made identical if it is too subtle.
| N/A
|-
| --wiki-content-border-color--accent
| style="background-color:var(--wiki-content-border-color--accent);" |
| A border color that is used as an accent. Usually this is <code>--wiki-accent-color</code> with 50% transparency, but it can be any variation of the accent color.
| N/A
|-
| --wiki-content-text-color
| style="background-color:var(--wiki-content-text-color);" |
| Text color for the main content area.
| style="background-color:var(--wiki-content-text-color);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span><br/>
|-
| --wiki-content-link-color
| style="background-color:var(--wiki-content-link-color);" |
| Links within the content area. Please do not make this red, as red links on wikis traditionally denote pages that don't exist.
| style="background-color:var(--wiki-content-link-color);" |
<span style="color:var(--wiki-content-link-label-color);">--wiki-content-link-label-color</span>
|-
| --wiki-content-link-label-color
| style="background-color:var(--wiki-content-link-label-color);" |
| This is used when placing text on an element with the link color as a background, such as a button.
| style="background-color:var(--wiki-content-link-label-color);" |
<span style="color:var(--wiki-content-link-color);">--wiki-content-link-color</span>
|-
| --wiki-content-link-color--visited
| style="background-color:var(--wiki-content-link-color--visited);" |
| The color of visited links. This is optional, and usually inherits <code>--wiki-content-link-color</code>.
| style="background-color:var(--wiki-content-link-color--visited);" |
<span style="color:var(--wiki-content-background-color);">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary);">--wiki-content-background-color--secondary</span>
|-
| --wiki-content-link-color--hover
| style="background-color:var(--wiki-content-link-color--hover);" |
| The color links change to when hovered over. This is optional, and usually inherits <code>--wiki-content-link-color</code>.
| style="background-color:var(--wiki-content-link-color--hover);" |
<span style="color:var(--wiki-content-background-color);">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary);">--wiki-content-background-color--secondary</span>
|-
| --wiki-content-redlink-color
| style="background-color:var(--wiki-content-redlink-color);" |
| The color of links to pages that don't exist. Since these should only rarely be seen, you can be a little lax about choosing a color that contrasts with the background, but it should still be legible.
| style="background-color:var(--wiki-content-redlink-color);" |
<span style="color:var(--wiki-content-background-color);">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary);">--wiki-content-background-color--secondary</span>
|-
| --wiki-content-text-mix-color
| style="background-color:var(--wiki-content-text-mix-color);" |
| A mix of <code>--wiki-content-text-color</code> and <code>--wiki-content-background-color</code>, calculated automatically. This is generally used to mark disabled elements or placeholder text.
| style="background-color:var(--wiki-content-text-mix-color);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span><br/>
<span style="color:var(--wiki-content-text-mix-color-95)">--wiki-content-text-mix-color-95</span>
|-
| --wiki-content-text-mix-color-95
| style="background-color:var(--wiki-content-text-mix-color-95);" |
| The same as <code>--wiki-content-text-mix-color</code>, but the mix is 95% <code>--wiki-content-background-color</code>, calculated automatically. This is used to mark disabled elements. The contrast checker to the right should actually be very hard to read but not impossible.
| style="background-color:var(--wiki-content-text-mix-color-95);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span>
|-
| --wiki-content-dynamic-color
| style="background-color:var(--wiki-content-dynamic-color);" |
| This is expected to contrast sharply with <code>--wiki-content-background-color</code>. Usually this is {{color|#000}} on light themes and {{color|#fff}} on dark themes.
| style="background-color:var(--wiki-content-dynamic-color);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color--inverted)">--wiki-content-dynamic-color--inverted</span><br/>
<span style="color:var(--wiki-content-dynamic-color--secondary--inverted)">--wiki-content-dynamic-color--secondary--inverted</span><br/>
|-
| --wiki-content-dynamic-color--inverted
| style="background-color:var(--wiki-content-dynamic-color--inverted);" |
| The inverse of <code>--wiki-content-dynamic-color</code>.
| style="background-color:var(--wiki-content-dynamic-color--inverted);" |
<span style="color:var(--wiki-content-dynamic-color)">--wiki-content-dynamic-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color--secondary)">--wiki-content-dynamic-color--secondary</span><br/>
|-
| --wiki-content-dynamic-color--secondary
| style="background-color:var(--wiki-content-dynamic-color--secondary);" |
| A slightly different version of <code>--wiki-content-dynamic-color</code>. Usually this is {{color|#333}} on light themes and {{color|#ccc}} on dark themes.
| style="background-color:var(--wiki-content-dynamic-color--secondary);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color--inverted)">--wiki-content-dynamic-color--inverted</span><br/>
<span style="color:var(--wiki-content-dynamic-color--secondary--inverted)">--wiki-content-dynamic-color--secondary--inverted</span><br/>
|-
| --wiki-content-dynamic-color--secondary--inverted
| style="background-color:var(--wiki-content-dynamic-color--secondary--inverted);" |
| The inverse of <code>--wiki-content-dynamic-color--secondary</code>.
| style="background-color:var(--wiki-content-dynamic-color--secondary--inverted);" |
<span style="color:var(--wiki-content-dynamic-color)">--wiki-content-dynamic-color</span><br/>
<span style="color:var(--wiki-content-dynamic-color--secondary)">--wiki-content-dynamic-color--secondary</span><br/>
|-
| --wiki-content-heading-color
| style="background-color:var(--wiki-content-heading-color);" |
| The color of headings, such as the page title and section headings. Usually this is set to <code>--wiki-content-text-color</code>, but feel free to give it a different color to spice up the theme a little.
| style="background-color:var(--wiki-content-heading-color);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span>
|-
| --wiki-accent-color
| style="background-color:var(--wiki-accent-color);" |
| Used to style infoboxes, navboxes, focused element outlines, and some buttons, such as the save button when editing.
| style="background-color:var(--wiki-accent-color);" |
<span style="color:var(--wiki-accent-label-color)">--wiki-accent-label-color</span><br/>
<span style="color:var(--wiki-accent-link-color)">--wiki-accent-link-color</span><br/>
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span><br/>
|-
| --wiki-accent-color--hover
| style="background-color:var(--wiki-accent-color--hover);" |
| The color of accent-color when hovered over, in some cases. Usually this is just accent-color with saturation and/or value reduced or increased by about 10%, but you're free to make it whatever you want provided the contrast checks to the right still pass.
| style="background-color:var(--wiki-accent-color--hover);" |
<span style="color:var(--wiki-accent-label-color)">--wiki-accent-label-color</span>
|-
| --wiki-accent-label-color
| style="background-color:var(--wiki-accent-label-color);" |
| The color of normal text against the accent color.
| style="background-color:var(--wiki-accent-label-color);" |
<span style="color:var(--wiki-accent-color)">--wiki-accent-color</span><br/>
<span style="color:var(--wiki-accent-color--hover)">--wiki-accent-color--hover</span><br/>
|-
| --wiki-accent-link-color
| style="background-color:var(--wiki-accent-link-color);" |
| The color of links against the accent color.
| style="background-color:var(--wiki-accent-link-color);" |
<span style="color:var(--wiki-accent-color)">--wiki-accent-color</span>
|-
| --wiki-sidebar-background-color
| style="background-color:var(--wiki-sidebar-background-color);" |
| The background color of the sidebar to the left of the content area. Usually this inherits <code>--wiki-content-background-color</code>.
| style="background-color:var(--wiki-sidebar-background-color);" |
<span style="color:var(--wiki-sidebar-link-color)">--wiki-sidebar-link-color</span><br/>
<span style="color:var(--wiki-sidebar-heading-color)">--wiki-sidebar-heading-color</span><br/>
|-
| --wiki-sidebar-border-color
| style="background-color:var(--wiki-sidebar-border-color);" |
| The border color of the sidebar. Usually this inherits <code>--wiki-content-border-color</code>.
| N/A
|-
| --wiki-sidebar-link-color
| style="background-color:var(--wiki-sidebar-link-color);" |
| The color of links in the sidebar. Usually this inherits <code>--wiki-content-link-color</code>.
| style="background-color:var(--wiki-sidebar-link-color);" |
<span style="color:var(--wiki-sidebar-background-color)">--wiki-sidebar-background-color</span>
|-
| --wiki-sidebar-link-color--hover
| style="background-color:var(--wiki-sidebar-link-color--hover);" |
| The color links change to when hovered over. This is optional, and usually inherits <code>--wiki-content-link-color--hover</code>.
| style="background-color:var(--wiki-sidebar-link-color--hover);" |
<span style="color:var(--wiki-sidebar-background-color)">--wiki-sidebar-background-color</span>
|-
| --wiki-sidebar-heading-color
| style="background-color:var(--wiki-sidebar-heading-color);" |
| The color of headings in the sidebar. Usually this inherits <code>--wiki-content-heading-color</code>.
| style="background-color:var(--wiki-sidebar-heading-color);" |
<span style="color:var(--wiki-sidebar-background-color)">--wiki-sidebar-background-color</span>
|-
| --wiki-navigation-background-color
| style="background-color:var(--wiki-navigation-background-color);" |
| The primary background color of the navigation tabs above the content area. Usually this inherits <code>--wiki-content-background-color--secondary</code>.
| style="background-color:var(--wiki-navigation-background-color);" |
<span style="color:var(--wiki-navigation-text-color)">--wiki-navigation-text-color</span><br/>
|-
| --wiki-navigation-background-color--secondary
| style="background-color:var(--wiki-navigation-background-color--secondary);" |
| The upper background color of the navigation tabs, as well as the background color of the "More" menu dropdown. Usually this inherits <code>--wiki-content-background-color</code>.
| style="background-color:var(--wiki-navigation-background-color--secondary);" |
<span style="color:var(--wiki-navigation-text-color)">--wiki-navigation-text-color</span><br/>
|-
| --wiki-navigation-border-color
| style="background-color:var(--wiki-navigation-border-color);" |
| Border color of the navigation tabs. Usually this inherits <code>--wiki-content-border-color</code>.
| N/A
|-
| --wiki-navigation-text-color
| style="background-color:var(--wiki-navigation-text-color);" |
| The color of text in the navigation tabs. Usually this inherits <code>--wiki-content-link-color</code>.
| style="background-color:var(--wiki-navigation-text-color);" |
<span style="color:var(--wiki-navigation-background-color)">--wiki-navigation-background-color</span><br/>
<span style="color:var(--wiki-navigation-background-color--secondary)">--wiki-navigation-background-color--secondary</span><br/>
|-
| --wiki-navigation-text-color--hover
| style="background-color:var(--wiki-navigation-text-color--hover);" |
| The color of text in the navigation tabs when hovered. Usually this inherits <code>--wiki-content-link-color--hover</code>.
| style="background-color:var(--wiki-navigation-text-color--hover);" |
<span style="color:var(--wiki-navigation-background-color)">--wiki-navigation-background-color</span><br/>
<span style="color:var(--wiki-navigation-background-color--secondary)">--wiki-navigation-background-color--secondary</span><br/>
|-
| --wiki-navigation-selected-background-color
| style="background-color:var(--wiki-navigation-selected-background-color);" |
| The background color of the currently active navigation tab. Usually this inherits <code>--wiki-content-background-color</code>
| style="background-color:var(--wiki-navigation-selected-background-color);" |
<span style="color:var(--wiki-navigation-selected-text-color)">--wiki-navigation-selected-text-color</span><br/>
|-
| --wiki-navigation-selected-border-color
| style="background-color:var(--wiki-navigation-selected-border-color);" |
| The border color of the currently active navigation tab. Usually this inherits <code>--wiki-navigation-border-color</code>
| N/A
|-
| --wiki-navigation-selected-text-color
| style="background-color:var(--wiki-navigation-selected-text-color);" |
| The text color of the currently active navigation tab. Usually this inherits <code>--wiki-content-text-color</code>
| style="background-color:var(--wiki-navigation-selected-text-color);" |
<span style="color:var(--wiki-navigation-selected-background-color)">--wiki-navigation-selected-background-color</span><br/>
|-
| --wiki-neutral-color
| style="background-color:var(--wiki-neutral-color);" |
| A gray-ish color for displaying neutral text, such as a diff size of 0 in RecentChanges and page history. Usually this inherits <code>--wiki-content-text-mix-color</code>, but can be set explicitly if that color is not gray enough.
| style="background-color:var(--wiki-neutral-color);" |
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span>
|-
| --wiki-alert-color
| style="background-color:var(--wiki-alert-color);" |
| A general, usually red-ish color used for negative notices, most notably negative diffs in RecentChanges and page history, and the "cancel" button when editing.
| style="background-color:var(--wiki-alert-color);" |
<span style="color:var(--wiki-alert-label-color)">--wiki-alert-label-color</span><br/>
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span><br/>
|-
| --wiki-alert-label-color
| style="background-color:var(--wiki-alert-label-color);" |
| The color of text against <code>--wiki-alert-color</code> as a background.
| style="background-color:var(--wiki-alert-label-color);" |
<span style="color:var(--wiki-alert-color)">--wiki-alert-color</span><br/>
|-
| --wiki-warning-color
| style="background-color:var(--wiki-warning-color);" |
| A general, usually orange-ish color used for warning notices.
| style="background-color:var(--wiki-warning-color);" |
<span style="color:var(--wiki-warning-label-color)">--wiki-warning-label-color</span><br/>
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
|-
| --wiki-warning-label-color
| style="background-color:var(--wiki-warning-label-color);" |
| The color of text against <code>--wiki-warning-color</code> as a background.
| style="background-color:var(--wiki-warning-label-color);" |
<span style="color:var(--wiki-warning-color)">--wiki-warning-color</span><br/>
|-
| --wiki-success-color
| style="background-color:var(--wiki-success-color);" |
| A general, usually green-ish color used for success notices, most noticeably positive diffs in RecentChanges and page history.
| style="background-color:var(--wiki-success-color);" |
<span style="color:var(--wiki-success-label-color)">--wiki-success-label-color</span><br/>
<span style="color:var(--wiki-content-background-color)">--wiki-content-background-color</span><br/>
<span style="color:var(--wiki-content-background-color--secondary)">--wiki-content-background-color--secondary</span><br/>
|-
| --wiki-success-label-color
| style="background-color:var(--wiki-success-label-color);" |
| The color of text against <code>--wiki-success-color</code> as a background.
| style="background-color:var(--wiki-success-label-color);" |
<span style="color:var(--wiki-success-color)">--wiki-success-color</span><br/>
|}
<h2>Stylesheet</h2>
<!-- When rendered on common.css, the actual stylesheet will be right here -->
</div>
46bda3c0aabbc7ea35b816706b99b474a2dc06df
MediaWiki:DataMaps.css
8
247
271
2025-08-20T01:25:04Z
ARTIFICER
564804
Importing default loadout
css
text/css
/** Container */
.ext-datamaps-container-content .ext-datamaps-container-leaflet {
background: var(--wiki-content-background-color--secondary);
}
/** Legend */
.ext-datamaps-container .ext-datamaps-control-expandable[aria-expanded="true"] {
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 95%, transparent);
}
.ext-datamaps-container .oo-ui-tabOptionWidget {
color: var(--wiki-content-link-color);
}
.ext-datamaps-container .oo-ui-tabSelectWidget-frameless .oo-ui-tabOptionWidget.oo-ui-optionWidget-selected {
background: var(--wiki-content-link-color);
box-shadow: none;
color: var(--wiki-content-link-label-color);
}
/** Popups */
.ext-datamaps-container .leaflet-popup-content-wrapper,
.ext-datamaps-container .leaflet-popup-tip {
background: var(--wiki-content-background-color--secondary);
color: var(--wiki-content-text-color);
}
.ext-datamaps-container .ext-datamaps-popup-buttons a,
.ext-datamaps-container .leaflet-popup-close-button {
filter: var(--wiki-icon-general-filter);
cursor: pointer;
}
.ext-datamaps-popup-header .ext-datamaps-popup-subtitle, .ext-datamaps-popup-header .ext-datamaps-popup-location {
color: var(--wiki-content-text-mix-color);
}
.ext-datamaps-popup .ext-datamaps-popup-tools li a {
border: 1px solid var(--wiki-content-link-color);
transition: background 100ms, color 100ms;
}
.ext-datamaps-popup .ext-datamaps-popup-tools li a:hover {
background: var(--wiki-content-link-color);
color: var(--wiki-content-link-label-color);
}
/** Controls */
.ext-datamaps-container .leaflet-bar {
background-color: var(--wiki-content-background-color--secondary);
border-color: color-mix(in srgb, var(--wiki-content-link-color) 50%, transparent);
}
.ext-datamaps-container .leaflet-bar button:hover {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 25%, transparent);
}
.ext-datamaps-container .leaflet-control {
color: var(--wiki-content-text-color);
}
.leaflet-control-container .oo-ui-buttonElement > .oo-ui-buttonElement-button {
min-height: unset;
}
.ext-datamaps-container .leaflet-control button {
border-bottom-color: color-mix(in srgb, var(--wiki-content-link-color) 50%, transparent);
color: var(--wiki-content-text-color);
}
/* HACK: awful selector, v1.0 will prolly use a standard class on these */
.ext-datamaps-container .ext-datamaps-control span[class^="oo-ui-icon"] {
filter: var(--wiki-icon-general-filter);
}
/** Search */
.ext-datamaps-container .ext-datamaps-control-search ul.ext-datamaps-control-search-results {
background: var(--wiki-content-background-color--secondary);
}
.ext-datamaps-container .ext-datamaps-control-search ul.ext-datamaps-control-search-results li:focus,
.ext-datamaps-container .ext-datamaps-control-search ul.ext-datamaps-control-search-results li[data-highlighted="true"] {
background: color-mix(in srgb, var(--wiki-content-link-color) 15%, transparent);
color: var(--wiki-content-link-color);
}
.ext-datamaps-container .ext-datamaps-container-status > :not(.oo-ui-widget) {
background:var(--wiki-content-background-color--secondary);
color:var(--wiki-content-text-mix-color);
}
.ext-datamaps-container .leaflet-control-container .ext-datamaps-control-coords {
background: var(--background-color-neutral-subtle);
color: var(--color-base--subtle);
}
f3ef9024b4b537b9fa9bceff82bbbeaf0feb7f7a
MediaWiki:Gadgets/mpEditLinks/main.js
8
248
272
2025-08-20T01:25:05Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
$.when( $.ready )
.then(function(){
if(!document.getElementById('mp-container')) return;
var rootpage = document.getElementById('mp-container').dataset['rootpage']; // Get the rootpage passed from the main page module, so we don't need to make an API call
/* generate the links here instead of in the wikitext, so that users who can't see them don't have them
* in the DOM at all, and screenreaders and search engines don't get confused */
function createLinks(){
$('.mp-box').each(function(_, el){
var params = '?action=edit';
// only add the long preload stuff if the box doesn't exist, for prettier urls
if ( $(el).hasClass('missing') ){
params += '&preload=Template:Main page box/preload&preloadparams[0]=' + el.dataset['boxId'].charAt(0).toUpperCase() + el.dataset['boxId'].slice(1); /* preloadparam is box id with first letter capitalized */
}
$('<a></a>', {href: mw.util.getUrl(rootpage + '/' + el.dataset['boxId']) + params})
.msg('gadget-mpEditLinks-edit-link-text', rootpage + '/' + el.dataset['boxId'])
.appendTo(
$('<div></div>', {
class: 'mp-edit-link'
}).prependTo(el)
);
});
}
function toggleLinks(){
$('.mp-edit-link').each(function(_, el){
$(el).toggle().css('display none;');
});
}
$('<span></span>', {
text: mw.msg('gadget-mpEditLinks-toggle-link-text'),
class: 'mp-edit-toggle',
on: {click: toggleLinks},
}).appendTo($('#top'));
createLinks();
});
6174d3c34c950700a1700ea0707b008195b25ce1
MediaWiki:Gadgets/mpEditLinks/main.css
8
249
273
2025-08-20T01:25:06Z
ARTIFICER
564804
Importing default loadout
css
text/css
.mp-edit-link {
display:block;
position:absolute;
z-index:99;
right:0.5em;
top:0.5em;
background:var(--wiki-content-background-color);
}
.mp-edit-link a {
display:block;
padding:0.1em;
border:1px solid var(--wiki-content-link-color);
}
.mp-edit-link a::before {
display:inline-block;
content:'';
background-image:url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2220%22 height=%2220%22 viewBox=%220 0 20 20%22%3E%3Ctitle%3E edit %3C/title%3E%3Cpath d=%22m16.77 8 1.94-2a1 1 0 0 0 0-1.41l-3.34-3.3a1 1 0 0 0-1.41 0L12 3.23zM1 14.25V19h4.75l9.96-9.96-4.75-4.75z%22/%3E%3C/svg%3E");
background-size:contain;
width:1em;
height:1em;
filter:var(--wiki-icon-to-link-filter);
vertical-align:text-top;
margin-right:0.2em;
}
c5fd62c547dd14df99d3f223cdca962743d492d1
MediaWiki:Gadgets/ranger/main.css
8
250
274
2025-08-20T01:25:06Z
ARTIFICER
564804
Importing default loadout
css
text/css
/** as of Module:navbox version 1.2.4 **/
.ranger-navbox{
border-color: var(--navbox-outer-border-color);
border-style: var(--navbox-outer-border-style);
border-width: var(--navbox-outer-border-width);
border-radius: var(--navbox-outer-border-radius);
padding: var(--navbox-padding);
font-size: var(--navbox-font-size);
margin: var(--navbox-margin);
background: var(--navbox-background);
line-height: 1.5;
clear:both;
}
.ranger-navbox * {
border: 0;
}
.ranger-navbox .center *{
margin-left: unset;
margin-right: unset;
}
.ranger-navbox,
.ranger-navbox .ranger-section,
.ranger-navbox .ranger-listbox{
display: flex;
flex-direction: column;
gap: var(--navbox-gap);
}
.ranger-navbox .ranger-title,
.ranger-navbox .ranger-header{
text-align: center;
min-height: 1.5em;
position: relative;
z-index: 0;
font-weight: bold;
}
.ranger-navbox .ranger-title{
color: var(--navbox-title-color);
background: var(--navbox-title-background);
font-size: var(--navbox-title-font-size);
padding: var(--navbox-title-padding--y) calc(1.5em + var(--navbox-icon-offset--x)); /* left and right padding equal to the size and position of the edit/collapse buttons */
}
.ranger-navbox .ranger-title a,
.ranger-navbox .ranger-title a:visited,
.ranger-navbox .ranger-title a:hover,
.ranger-navbox .ranger-title a.external,
.ranger-navbox .ranger-title a.external:visited,
.ranger-navbox .ranger-title a.external:hover {
text-decoration: var(--navbox-title-link-decoration);
}
.ranger-navbox .ranger-title a.new,
.ranger-navbox .ranger-title a.new:visited {
text-decoration: var(--navbox-title-redlink-decoration);
}
.ranger-navbox .ranger-title a,
.ranger-navbox .ranger-title a.external,
.ranger-navbox .ranger-title a.external:visited {
color: var(--navbox-title-link-color);
}
.ranger-navbox .ranger-title a:visited{
color: var(--navbox-title-link-color--visited);
}
.ranger-navbox .ranger-title a.new,
.ranger-navbox .ranger-title a.new:visited{
color:var(--navbox-title-redlink-color);
}
.ranger-navbox .ranger-title a:hover,
.ranger-navbox .ranger-title a:visited:hover,
.ranger-navbox .ranger-title a.external:hover,
.ranger-navbox .ranger-title a.external:visited:hover {
color:var(--navbox-title-link-color--hover);
}
.ranger-navbox .ranger-header{
color: var(--navbox-header-color);
background: var(--navbox-header-background);
font-size: var(--navbox-header-font-size);
padding: var(--navbox-header-padding--y) calc(1.5em + var(--navbox-icon-offset--x)); /* left and right padding equal to the size and position of the edit/collapse buttons */
}
.ranger-navbox .ranger-sublist .ranger-header{
font-size: var(--navbox-subheader-font-size);
padding: var(--navbox-subheader-padding--y) calc(1.5em + var(--navbox-icon-offset--x)); /* left and right padding equal to the size and position of the edit/collapse buttons */
}
.ranger-navbox .ranger-header a,
.ranger-navbox .ranger-header a:visited,
.ranger-navbox .ranger-header a:hover,
.ranger-navbox .ranger-header a.external,
.ranger-navbox .ranger-header a.external:visited,
.ranger-navbox .ranger-header a.external:hover {
text-decoration: var(--navbox-header-link-decoration);
}
.ranger-navbox .ranger-header a.new,
.ranger-navbox .ranger-header a.new:visited {
text-decoration: var(--navbox-header-redlink-decoration);
}
.ranger-navbox .ranger-header a,
.ranger-navbox .ranger-header a.external,
.ranger-navbox .ranger-header a.external:visited {
color: var(--navbox-header-link-color);
}
.ranger-navbox .ranger-header a:visited{
color: var(--navbox-header-link-color--visited);
}
.ranger-navbox .ranger-header a.new,
.ranger-navbox .ranger-header a.new:visited{
color:var(--navbox-header-redlink-color);
}
.ranger-navbox .ranger-header a:hover,
.ranger-navbox .ranger-header a:visited:hover,
.ranger-navbox .ranger-header a.external:hover,
.ranger-navbox .ranger-header a.external:visited:hover {
color:var(--navbox-header-link-color--hover);
}
.ranger-navbox .ranger-meta{
font-size: var(--navbox-title-font-size);
position: absolute;
left: var(--navbox-icon-offset--x);
top: calc(var(--navbox-title-padding--y) + 0.08em); /* 0.08em: vertial offset tweak based on the icon graph */
display: block;
}
.ranger-navbox .ranger-meta .nv{
--mask: var(--icon-metalinks);
display: block;
width: 0.84em; /* based on the icon graph */
height: 0.84em;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background-color: var(--navbox-title-icon-color);
}
.ranger-navbox .ranger-meta .nv > a{
display: block;
width: 100%;
height: 100%;
opacity: 0;
}
.ranger-navbox .ranger-meta .nv > a > span{
display: block;
width: 100%;
height: 100%;
overflow: hidden;
}
.ranger-navbox .ranger-meta:has(.mw-selflink){
display: none;
}
.ranger-navbox,
.ranger-navbox .ranger-section{
position: relative;
}
.ranger .mw-collapsible-toggle-placeholder{
display: none;
}
.ranger-navbox .ranger-title > .ranger-title-text,
.ranger-navbox .ranger-header > .ranger-header-text{
pointer-events: none;
}
.ranger-navbox .ranger-title > .ranger-title-text a,
.ranger-navbox .ranger-header > .ranger-header-text a{
pointer-events: auto;
}
.ranger-navbox .ranger-title > .mw-collapsible-toggle,
.ranger-navbox .ranger-header > .mw-collapsible-toggle{
--mask: var(--icon-chevron-down);
position: absolute;
right: 0;
top: 0;
z-index: -1;
display: block;
width: 100%;
height: 100%;
overflow:hidden;
}
.ranger-navbox.small-collapsible-toggle-click-area .ranger-title > .mw-collapsible-toggle,
.ranger-navbox.small-collapsible-toggle-click-area .ranger-header > .mw-collapsible-toggle{
width: 1.5em;
height: 1.5em;
right: var(--navbox-icon-offset--x);
}
.ranger-navbox.small-collapsible-toggle-click-area .ranger-title > .mw-collapsible-toggle{
top: var(--navbox-title-padding--y);
}
.ranger-navbox.small-collapsible-toggle-click-area .ranger-header > .mw-collapsible-toggle{
top: var(--navbox-header-padding--y);
}
.ranger-navbox.small-collapsible-toggle-click-area .ranger-sublist .ranger-header > .mw-collapsible-toggle{
top: var(--navbox-subheader-padding--y);
}
.ranger-navbox .ranger-title > .mw-collapsible-toggle::before,
.ranger-navbox .ranger-header > .mw-collapsible-toggle::before{
content: "";
display: block;
width: 1.5em;
height: 1.5em;
position: absolute;
right: var(--navbox-icon-offset--x);
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background-color: var(--navbox-title-icon-color);
transform: scaleY(-1);
}
.ranger-navbox .ranger-title > .mw-collapsible-toggle::before{
top: var(--navbox-title-padding--y);
}
.ranger-navbox .ranger-header > .mw-collapsible-toggle::before{
top: var(--navbox-header-padding--y);
}
.ranger-navbox .ranger-sublist .ranger-header > .mw-collapsible-toggle::before{
top: var(--navbox-subheader-padding--y);
}
.ranger-navbox.small-collapsible-toggle-click-area .ranger-title > .mw-collapsible-toggle::before,
.ranger-navbox.small-collapsible-toggle-click-area .ranger-header > .mw-collapsible-toggle::before{
top: 0;
right: 0;
}
.ranger-navbox .ranger-header > .mw-collapsible-toggle::before{
background-color: var(--navbox-header-icon-color);
}
.ranger-navbox .ranger-title > .mw-collapsible-toggle.mw-collapsible-toggle-collapsed::before,
.ranger-navbox .ranger-header > .mw-collapsible-toggle.mw-collapsible-toggle-collapsed::before{
transform: none;
}
.ranger-navbox .ranger-title > .mw-collapsible-toggle *,
.ranger-navbox .ranger-title > .mw-collapsible-toggle::after,
.ranger-navbox .ranger-header > .mw-collapsible-toggle *,
.ranger-navbox .ranger-header > .mw-collapsible-toggle::after{
display: none;
}
.ranger-navbox .ranger-list{
width: unset;
padding: var(--navbox-list-padding);
}
.ranger-navbox .ranger-above{
background: var(--navbox-above-background);
color: var(--navbox-above-color);
padding: var(--navbox-above-padding);
width: unset;
}
.ranger-navbox .ranger-below{
background: var(--navbox-below-background);
color: var(--navbox-below-color);
padding: var(--navbox-below-padding);
width: unset;
}
.ranger-navbox .ranger-sublist{
display: flex;
flex-direction: column;
gap: var(--navbox-gap);
}
.ranger-navbox .ranger-section-body{
display: grid;
gap: var(--navbox-gap);
grid-template-columns: auto minmax(0,1fr);
}
/* gap fix for collapsed content */
.ranger-navbox [class^="ranger-"][hidden="until-found"]{
margin-top: calc(0px - var(--navbox-gap)) !important;
}
.ranger-navbox .ranger-row{
display: contents;
}
.ranger-navbox .ranger-group,
.ranger-navbox .ranger-subgroup{
text-align: var(--navbox-group-text-align);
font-weight: bold;
background: var(--navbox-group-background);
color: var(--navbox-group-color);
padding: var(--navbox-group-padding);
width: unset;
}
/* for desktop view */
.ranger-navbox.group-align-left .ranger-group,
.ranger-navbox.group-align-left .ranger-subgroup{
--navbox-group-text-align: left;
}
.ranger-navbox.group-align-center .ranger-group,
.ranger-navbox.group-align-center .ranger-subgroup{
--navbox-group-text-align: center;
}
.ranger-navbox.group-align-right .ranger-group,
.ranger-navbox.group-align-right .ranger-subgroup{
--navbox-group-text-align: right;
}
/* for mobile view */
.ranger-navbox.mobile-group-align-left .ranger-group,
.ranger-navbox.mobile-group-align-left .ranger-subgroup{
--navbox-group-text-align--mobile: left;
}
.ranger-navbox.mobile-group-align-center .ranger-group,
.ranger-navbox.mobile-group-align-center .ranger-subgroup{
--navbox-group-text-align--mobile: center;
}
.ranger-navbox.mobile-group-align-right .ranger-group,
.ranger-navbox.mobile-group-align-right .ranger-subgroup{
--navbox-group-text-align--mobile: right;
}
/* for desktop view */
.ranger-navbox.list-align-left .ranger-listbox{
--navbox-list-text-align: left;
}
.ranger-navbox.list-align-center .ranger-listbox{
--navbox-list-text-align: center;
}
.ranger-navbox.list-align-right .ranger-listbox{
--navbox-list-text-align: right;
}
/* for mobile view */
.ranger-navbox.mobile-list-align-left .ranger-listbox{
--navbox-list-text-align--mobile: left;
}
.ranger-navbox.mobile-list-align-center .ranger-listbox{
--navbox-list-text-align--mobile: center;
}
.ranger-navbox.mobile-list-align-right .ranger-listbox{
--navbox-list-text-align--mobile: right;
}
.ranger-navbox .ranger-listbox > .ranger-wrap{
text-align: var(--navbox-list-text-align);
background: var(--navbox-list-background);
color: var(--navbox-list-color);
flex-grow: 1;
}
.ranger-navbox .ranger-sublist{
flex-grow: var(--count);
}
.ranger-navbox .ranger-listbox:first-child{ /* A list-n without group-n */
grid-column-end: span 2;
}
.ranger-navbox .ranger-group,
.ranger-navbox .ranger-subgroup,
.ranger-navbox .ranger-listbox > .ranger-wrap{
display: grid;
justify-items: stretch;
align-items: center;
}
.ranger-navbox.striped-even .ranger-even,
.ranger-navbox.striped-odd .ranger-odd{
background: var(--navbox-list-background--striped);
}
/* make links use full line height (larger click box)*/
.ranger-navbox .hlist a{
display: inline-block;
}
.ranger-navbox .align-left,
.ranger-navbox .alignleft{
text-align: left;
}
.ranger-navbox .align-center,
.ranger-navbox .aligncenter{
text-align: center;
}
.ranger-navbox .align-right,
.ranger-navbox .alignright{
text-align: right;
}
/* responsive */
@media screen and (max-width: 720px) {
.ranger-navbox .ranger-section-body,
.ranger-navbox .ranger-sublist {
display: flex;
flex-flow: column;
}
.ranger-navbox .ranger-row{
display: block;
}
.ranger-navbox .ranger-group + .ranger-listbox > .ranger-sublist:first-child,
.ranger-navbox .ranger-subgroup + .ranger-listbox > .ranger-sublist:first-child{
margin-top: var(--navbox-gap);
}
.ranger-navbox .ranger-listbox.empty{
display: none;
}
.ranger-navbox .ranger-group,
.ranger-navbox .ranger-subgroup{
text-align: var(--navbox-group-text-align--mobile, left);
max-width: unset !important;
}
.ranger-navbox .ranger-group > *,
.ranger-navbox .ranger-subgroup > *{
max-width: unset !important;
}
.ranger-navbox .ranger-sublist {
padding-left: var(--navbox-tree-indent);
margin-left: var(--navbox-tree-line-indent);
}
.ranger-navbox .ranger-subgroup,
.ranger-navbox .ranger-listbox {
position:relative;
}
.ranger-navbox .ranger-group br,
.ranger-navbox .ranger-subgroup br{
display: none;
}
.ranger-navbox .ranger-listbox > .ranger-wrap{
text-align: var(--navbox-list-text-align--mobile, left);
}
.ranger-navbox .ranger-sublist > .ranger-section > .ranger-header{
margin-left: calc( 0px - var(--navbox-tree-indent) - var(--navbox-tree-line-indent));
}
.ranger-navbox .ranger-sublist .ranger-row > ::before{
position: absolute;
left: calc(0px - var(--navbox-tree-indent));
top: 0;
width: var(--navbox-tree-line-width);
height: 100%;
content: '';
display: block;
background-color: var(--navbox-tree-line-color);
}
.ranger-navbox .ranger-sublist .ranger-row > .ranger-listbox::before,
.ranger-navbox .ranger-row.empty-list > .ranger-subgroup::before{
height: calc(100% + var(--navbox-gap));
}
.ranger-navbox .ranger-sublist .ranger-row:last-child > ::before {
display: none;
}
.ranger-navbox .ranger-sublist .ranger-row:last-child > :first-child::before {
display: block;
height: calc(50% + var(--navbox-tree-line-width)/2);
}
.ranger-navbox .ranger-subgroup::after,
.ranger-navbox .ranger-row .ranger-row.empty-group > .ranger-listbox > .ranger-wrap::after{
position: absolute;
left: calc(0px - var(--navbox-tree-indent) + var(--navbox-tree-line-width));
width: calc(var(--navbox-tree-indent) - var(--navbox-tree-line-spacing) - var(--navbox-tree-line-width));
height: var(--navbox-tree-line-width);
content: '';
background-color: var(--navbox-tree-line-color);
}
/* increase height for links */
.ranger-navbox .hlist{
line-height: 2;
}
}
/**** `.pill` class: the "pill" style ****/
/* remove middle dots betweem items */
.ranger-navbox.pill .hlist dd:not(:last-child)::after,
.ranger-navbox.pill .hlist li:not(:last-child)::after{
display: none;
}
/* remove parentheses around nested lists*/
.ranger-navbox.pill .hlist dd ol::before,
.ranger-navbox.pill .hlist dd ul::before,
.ranger-navbox.pill .hlist dd dl::before,
.ranger-navbox.pill .hlist dt ol::before,
.ranger-navbox.pill .hlist dt ul::before,
.ranger-navbox.pill .hlist dt dl::before,
.ranger-navbox.pill .hlist li ol::before,
.ranger-navbox.pill .hlist li ul::before,
.ranger-navbox.pill .hlist li dl::before,
.ranger-navbox.pill .hlist dd ol::after,
.ranger-navbox.pill .hlist dd ul::after,
.ranger-navbox.pill .hlist dd dl::after,
.ranger-navbox.pill .hlist dt ol::after,
.ranger-navbox.pill .hlist dt ul::after,
.ranger-navbox.pill .hlist dt dl::after,
.ranger-navbox.pill .hlist li ol::after,
.ranger-navbox.pill .hlist li ul::after,
.ranger-navbox.pill .hlist li dl::after {
display: none;
}
/* make lists inline-flex */
.ranger-navbox.pill .hlist ul,
.ranger-navbox.pill .hlist ol,
.ranger-navbox.pill .hlist dl{
display: inline-flex;
gap: var(--navbox-pill-gap);
flex-wrap: wrap;
}
/* "pill" style for items */
.ranger-navbox.pill .hlist li,
.ranger-navbox.pill .hlist dt,
.ranger-navbox.pill .hlist dd{
padding: var(--navbox-pill-padding);
border-radius: var(--navbox-pill-border-radius);
box-shadow: var(--navbox-pill-box-shadow);
background: var(--navbox-pill-background);
/* 100% height */
display: flex;
align-items: center;
/* for nested lists */
gap: var(--navbox-pill-gap);
flex-wrap: wrap;
}
/* Add a hover / focus feedback style */
.ranger-navbox.pill .hlist dd:hover,
.ranger-navbox.pill .hlist dd:focus,
.ranger-navbox.pill .hlist dt:hover,
.ranger-navbox.pill .hlist dt:focus,
.ranger-navbox.pill .hlist li:hover,
.ranger-navbox.pill .hlist li:focus {
box-shadow: var(--navbox-pill-box-shadow--hover);
background: var(--navbox-pill-background--hover);
}
/* pill with selflink
*
* Only select the deepest level for nested lists.
* We have to use :has() to pick pills with selflink and
* all browsers which support :has() should also support :is() and :not(),
* therefore we can use :is() and :not() here safely.
*/
.ranger-navbox.pill .hlist .ranger-list :is(li,dt,dd):has(.mw-selflink):not(:has(li, dt, dd)){
background: var(--navbox-pill-selflink-background);
}
/**** `.pill-mobile` class: only apply the "pill" style on mobile ****/
@media screen and (max-width: 720px) {
/* remove middle dots betweem items */
.ranger-navbox.pill-mobile .hlist dd:not(:last-child)::after,
.ranger-navbox.pill-mobile .hlist li:not(:last-child)::after{
display: none;
}
/* remove parentheses around nested lists*/
.ranger-navbox.pill-mobile .hlist dd ol::before,
.ranger-navbox.pill-mobile .hlist dd ul::before,
.ranger-navbox.pill-mobile .hlist dd dl::before,
.ranger-navbox.pill-mobile .hlist dt ol::before,
.ranger-navbox.pill-mobile .hlist dt ul::before,
.ranger-navbox.pill-mobile .hlist dt dl::before,
.ranger-navbox.pill-mobile .hlist li ol::before,
.ranger-navbox.pill-mobile .hlist li ul::before,
.ranger-navbox.pill-mobile .hlist li dl::before,
.ranger-navbox.pill-mobile .hlist dd ol::after,
.ranger-navbox.pill-mobile .hlist dd ul::after,
.ranger-navbox.pill-mobile .hlist dd dl::after,
.ranger-navbox.pill-mobile .hlist dt ol::after,
.ranger-navbox.pill-mobile .hlist dt ul::after,
.ranger-navbox.pill-mobile .hlist dt dl::after,
.ranger-navbox.pill-mobile .hlist li ol::after,
.ranger-navbox.pill-mobile .hlist li ul::after,
.ranger-navbox.pill-mobile .hlist li dl::after {
display: none;
}
/* make lists inline-flex */
.ranger-navbox.pill-mobile .hlist ul,
.ranger-navbox.pill-mobile .hlist ol,
.ranger-navbox.pill-mobile .hlist dl{
display: inline-flex;
gap: var(--navbox-pill-gap);
flex-wrap: wrap;
}
/* "pill" style for items */
.ranger-navbox.pill-mobile .hlist li,
.ranger-navbox.pill-mobile .hlist dt,
.ranger-navbox.pill-mobile .hlist dd{
/* 100% height */
display: flex;
align-items: center;
/* for nested lists */
gap: var(--navbox-pill-gap);
flex-wrap: wrap;
}
/* "pill" style for items */
.ranger-navbox.pill-mobile .hlist li,
.ranger-navbox.pill-mobile .hlist dt,
.ranger-navbox.pill-mobile .hlist dd{
padding: var(--navbox-pill-padding);
border-radius: var(--navbox-pill-border-radius);
box-shadow: var(--navbox-pill-box-shadow);
background: var(--navbox-pill-background);
/* 100% height */
display: flex;
align-items: center;
/* for nested lists */
gap: var(--navbox-pill-gap);
flex-wrap: wrap;
}
/* Add a hover / focus feedback style */
.ranger-navbox.pill-mobile .hlist dd:hover,
.ranger-navbox.pill-mobile .hlist dd:focus,
.ranger-navbox.pill-mobile .hlist dt:hover,
.ranger-navbox.pill-mobile .hlist dt:focus,
.ranger-navbox.pill-mobile .hlist li:hover,
.ranger-navbox.pill-mobile .hlist li:focus {
box-shadow: var(--navbox-pill-box-shadow--hover);
background: var(--navbox-pill-background--hover);
}
/* pill with selflink
*
* Only select the deepest level for nested lists.
* We have to use :has() to pick pills with selflink and
* all browsers which support :has() should also support :is() and :not(),
* therefore we can use :is() and :not() here safely.
*/
.ranger-navbox.pill-mobile .hlist .ranger-list :is(li,dt,dd):has(.mw-selflink):not(:has(li, dt, dd)){
background: var(--navbox-pill-selflink-background);
}
}
/*********************
* End Template:Navbox*
**********************/
fe54cb7ce715e835bcc0c972d76364cbc18f5bc6
MediaWiki:Gadgets/ranger
8
251
275
2025-08-20T01:25:07Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": false,
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [
"Pages with navboxes"
],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"variables.css",
"main.css",
"custom.css"
],
"dependencies": [],
"type": "styles"
}
}
0e59fa9520b52214b9fedaecae9f41d86afd197f
MediaWiki:Gadgets/druid
8
252
276
2025-08-20T01:25:08Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"package": false,
"section": "",
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [
"Pages with DRUID infoboxes"
],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"variablesEditMe.css",
"mainReadonly.css",
"customEditMe.css"
],
"dependencies": [],
"type": "styles"
}
}
5c21b27bf41aba17b090e0d888010c308bd5d0bb
MediaWiki:Gadgets/druid/mainReadonly.css
8
253
277
2025-08-20T01:25:08Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* --------------------------------------------- */
/* Do not edit this file please */
/* You can edit variablesEditMe and customEditMe */
/* --------------------------------------------- */
.druid-container {
border: 4px solid var(--druid-border-color);
border-radius: 3px;
background: var(--druid-background-color);
float: right;
clear: right;
margin: 0 0 1em 1em;
width:100%;
max-width:22em;
box-sizing: border-box;
border-collapse: collapse;
}
@media screen and (max-width: 720px) {
.druid-container {
float: none;
margin: 0.5rem auto;
}
}
.druid-main-images-file,
.druid-main-image {
text-align:center;
}
.druid-infobox .druid-title,
.druid-infobox .druid-section {
background:var(--druid-secondary-background-color); /* fallback */
background:color-mix(in srgb, var(--druid-secondary-background-color) 75%, transparent);
color:var(--druid-secondary-background-label-color);
text-align:center;
font-size:1.5em;
padding:1px;
}
.druid-infobox .druid-section {
font-size: 1.25em;
font-weight: 500;
}
.druid-infobox .druid-collapsible .druid-section {
flex-grow: 1;
}
.druid-label {
font-weight:bold;
text-align: right;
box-sizing: border-box;
}
.druid-row > .druid-label {
width: 48%;
flex-shrink: 0;
}
.druid-row > .druid-label,
.druid-row > .druid-data {
padding-inline: 0.3em;
}
.druid-main-image,
.druid-main-images {
padding:5px;
}
.druid-main-image img,
.druid-main-images img {
max-width:100%;
height:auto;
}
.druid-main-images-labels {
display:flex;
flex-direction:row;
flex-wrap:wrap;
justify-content: space-evenly;
margin:0.25em;
gap:0.25em;
}
.druid-main-images-label {
cursor:pointer;
flex:1 1 auto;
text-align:center;
transition:.1s ease-in;
outline:1px solid var(--druid-link-color);
}
.druid-main-images-label.focused {
background:var(--druid-link-color);
color:var(--druid-link-label-color);
}
.druid-main-images-label:not(.focused):hover {
background:var(--druid-link-color); /* fallback */
background:color-mix(in srgb, var(--druid-link-color) 25%, transparent);
}
.druid-toggleable-data:not(.focused),
.druid-main-images-file:not(.focused),
.druid-toggleable-heading:not(.focused),
.druid-row:not(:has(.druid-grid)):has(.druid-toggleable-data-empty.focused),
.druid-grid-item:has(.druid-toggleable-data-empty.focused),
.druid-section:has(.druid-toggleable-heading-empty.focused),
.druid-section-container:has(.druid-toggleable-data-empty.focused):not(:has(.druid-toggleable-data-nonempty.focused)):not(:has(.druid-data-nonempty)) {
display:none;
}
.druid-grid {
display:grid;
gap: 0.3em;
padding: 0.35em;
}
.druid-grid-item {
background:var(--druid-tertiary-background-color);
padding:0.25em;
border:1px solid var(--druid-border-color); /* fallback */
border:1px solid color-mix(in srgb, var(--druid-border-color) 50%, transparent);
border-radius: 2px;
}
.druid-grid-item .druid-label,
.druid-grid-item .druid-data {
text-align: center;
}
.druid-data-wide {
width:100%;
}
.druid-section-container > .druid-collapsible {
display: flex;
justify-content: space-between;
align-items: center;
}
.druid-collapsed {
display:none !important;
}
.druid-collapsible {
cursor:pointer;
position:relative;
}
.druid-collapsible::after {
content: "";
display: block;
position: absolute;
right: 10px;
width: 20px;
height: 20px;
--mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Ctitle%3E collapse %3C/title%3E%3Cpath d='M1 13.75l1.5 1.5 7.5-7.5 7.5 7.5 1.5-1.5-9-9-9 9z'/%3E%3C/svg%3E") no-repeat;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background-color: var(--druid-secondary-background-label-color);
}
.druid-collapsible-collapsed::after {
transform: rotate(180deg);
}
/*****************************************
Div support
*****************************************/
div.druid-row {
display:flex;
margin-block: 1px;
}
div.druid-row + div.druid-row {
margin-top: 0;
}
div.druid-row > .druid-label {
background: var(--druid-tertiary-background-color);
}
.druid-infobox .druid-title {
font-weight: 700;
}
.druid-infobox #toc {
display:none;
}
/********
Custom display classes
*********/
div.druid-stacked.druid-row,
.druid-stacked div.druid-row {
flex-direction: column;
}
.druid-stacked.druid-row > .druid-label,
.druid-stacked .druid-row > .druid-label {
text-align: left;
width: 100%;
flex-basis:unset;
}
.druid-stacked.druid-row > .druid-data,
.druid-stacked .druid-row > .druid-data {
padding-left: .75em;
}
/* --------------------------------------------- */
/* Do not edit this file please */
/* You can edit variablesEditMe and customEditMe */
/* --------------------------------------------- */
b012f61bd994e50b85508138467794f6a296ed2d
MediaWiki:Gadgets/druid/variablesEditMe.css
8
254
278
2025-08-20T01:25:09Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* These variables are designed to inherit from your wiki's color variables.
If your wiki uses a different naming scheme, change the inner names to match yours.
If your wiki doesn't use color variables you should consider doing so,
otherwise you can replace the inner variables or the fallback values with colors that match your wiki.
*/
/* Light and dark are separated to make it easier for you to do local customizations but in the default version they are identical */
:root, .view-light .druid-container {
--druid-background-color: var(--wiki-content-background-color, #ffffff);
--druid-secondary-background-color: var(--wiki-accent-color, #36c);
--druid-secondary-background-label-color: var(--wiki-accent-label-color, #fff);
--druid-tertiary-background-color: var(--wiki-content-background-color--secondary, #eaecf0);
--druid-border-color: var(--wiki-content-border-color, #a7d7f9);
--druid-link-color: var(--wiki-content-link-color, #0645ad);
--druid-link-label-color: var(--wiki-content-link-label-color, #fff);
}
.view-dark .druid-container {
--druid-background-color: var(--wiki-content-background-color, #101418);
--druid-secondary-background-color: var(--wiki-accent-color, #36c);
--druid-secondary-background-label-color: var(--wiki-accent-label-color, #fff);
--druid-tertiary-background-color: var(--wiki-content-background-color--secondary, #202122);
--druid-border-color: var(--wiki-content-border-color, #72777d);
--druid-link-color: var(--wiki-content-link-color, #6d8afb);
--druid-link-label-color: var(--wiki-content-link-label-color, #000);
}
8fbdba8a0bd21c0bc819a404a5bec10170782fc2
MediaWiki:Gadgets/druid/customEditMe.css
8
255
279
2025-08-20T01:25:09Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* Custom DRUID styles should go here */
7ecb3c635f03ba714e419c200113f47043f0e358
MediaWiki:Gadgets/druid/doc
8
256
280
2025-08-20T01:25:10Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
<includeonly>This gadget provides styles for {{ml|Infobox}}. You can customize:
* [[MediaWiki:Gadgets/druid/variablesEditMe.css]] - to customize the built-in variables (e.g. if you want to make the color of your infobox not match the wiki accent color). This file will load '''first''' out of all of the DRUID CSS files.
* [[MediaWiki:Gadgets/druid/customEditMe.css]] - to otherwise customize DRUID (e.g. if you want to change the padding, or add a border image, something that's not supported through variables. This file will load '''last''' out of all of the DRUID CSS files, so all rules here will overwrite rules in [[MediaWiki:Gadgets/druid/mainReadonly.css]] with equal specificity.
Please do NOT modify [[MediaWiki:Gadgets/druid/mainReadonly.css]]!! That page may be updated by wiki.gg staff via script, and the updates will not function if you modify it.
More documentation can be found at [[support:DRUID infoboxes|DRUID infoboxes]]<!--
--></includeonly><noinclude>This is the documentation page for [[{{#titleparts:{{FULLPAGENAME}}|-1}}]].</noinclude>
2813eb77787e37161b0ed7e4e85c9f5f2d7ad92e
MediaWiki:Newarticletext
8
257
281
2025-08-20T01:25:10Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
You have followed a link to a page that does not exist yet.
To create the page, start typing in the box below (see the [$1 help page] for more info).
If you are here by mistake, click your browser's <strong>back</strong> button.
778f9ef242eb3058ef30ed3325b901adb762a2af
MediaWiki:Gadgets
8
258
282
2025-08-20T01:25:11Z
ARTIFICER
564804
Importing default loadout
wikitext
text/x-wiki
See also: [[Special:Gadgets]] for a list of all installed gadgets, formatted in a friendly way.
{{Special:PrefixIndex/MediaWiki:Gadgets}}
14815d26ea4ae878b5e77e1781eeb35cd742ad2c
MediaWiki:Gadgets/druidScripts
8
259
283
2025-08-20T01:25:12Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [
"Pages with DRUID infoboxes"
],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.js"
],
"dependencies": [
"jquery"
],
"type": "general"
}
}
5df47905f5c565c4a5c0da774413a6dee76eb7d1
MediaWiki:Gadgets/druidScripts/main.js
8
260
284
2025-08-20T01:25:12Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
mw.hook( 'wikipage.content' ).add( () => {
$( '.druid-title-tab' ).off( 'click' )
.on( 'click', function () {
const $parent = $( this ).closest( '.druid-container' );
$parent.find( '.druid-toggleable' ).removeClass( 'focused' );
const i = $( this ).attr( 'data-druid' );
$parent.find( `.druid-toggleable[data-druid="${i}"]` ).addClass( 'focused' );
} );
$( '.druid-section-tab' ).off( 'click' )
.on( 'click', function () {
const $parent = $( this ).closest( '.druid-section-container' );
$parent.find( '.druid-toggleable' ).removeClass( 'focused' );
const i = $( this ).attr( 'data-druid' );
$parent.find( `.druid-toggleable[data-druid="${i}"]` ).addClass( 'focused' );
} );
$( '.druid-collapsible' ).off( 'click' )
.on( 'click', function () {
const kind = $( this ).attr( 'data-druid-section' );
$( this )
.toggleClass( 'druid-collapsible-collapsed' )
.closest( '.druid-container' )
.find( `[data-druid-section-row="${kind}"]` )
.toggleClass( 'druid-collapsed' );
} );
} );
/* End DRUID */
af8f73fc414f3fc0dae8d97a044675e9912fa457
MediaWiki:Gadgets/discordTemplate
8
261
285
2025-08-20T01:25:13Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [
"Pages with Discord embeds"
],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.js"
],
"dependencies": [
"jquery"
],
"type": "general"
}
}
1232b7fbe2ff589295233393f6f387cf52793a2a
MediaWiki:Gadgets/discordTemplate/main.js
8
262
286
2025-08-20T01:25:13Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
/**
* DiscordCompact.js
* ----------------------
* A very simple script to display a Discord widget.
* Version 0.0.2
* https://support.wiki.gg/wiki/DiscordCompact
* ----------------------
*/
$(function() {
var widget = $("#content #discord-compact-widget");
// Bail out if we didn't find a widget.
if (!widget.length) return;
var id = widget.attr("data-id");
// Ensure that the id is not blank.
if (id === "") throw new Error("DiscordCompact has a blank server id!");
// Ensure that the id consists only of numbers and is at least 17 characters long.
if (!new RegExp("^[0-9]{17}[0-9]+$").test(id)) throw new Error("DiscordCompact has an invalid server id!");
var apiBase = "https://discord.com/api/guilds/" + id;
// Get some information about the server, such as online member count and invite url.
// This also tells us if the server exists or has widgets disabled, so we look out for that too.
$.ajax(apiBase + "/widget.json").fail(function(req){
if (!req.responseJSON) throw new Error("DiscordCompact encountered an unknown error whilst fetching widget.json (status: " + req.status);
switch (req.responseJSON.code) {
case 10004:
throw new Error("DiscordCompact has a valid server id, but no such server exists!");
case 50004:
throw new Error("DiscordCompact has a valid server id, but that server has widgets disabled!");
default:
throw new Error("DiscordCompact encountered an unknown error whilst fetching widget.json (status: " + req.status + "; code: " + req.responseJSON.code + ")");
}
}).done(function(res){
const inviteURL = res.instant_invite;
// Warn if we can't get an invite URL.
if (inviteURL == null) console.warn("DiscordCompact cannot get an invite URL; does this server have an invite channel set in Widget settings?");
// Now get the widget image.
$.ajax({url: apiBase + "/widget.png?style=banner2", xhrFields: {responseType: "blob"}}).fail(function(req){
if (!req.responseJSON) throw new Error("DiscordCompact encountered an unknown error whilst fetching widget.png! (status: " + req.status);
throw new Error("DiscordCompact encountered an unknown error whilst fetching widget.png! (status: " + req.status + "; code: " + req.responseJSON.code + ")");
}).done(function(blob){
// Convert the image data into base64. This prevents us having to make the client request it a second time.
const imageReader = new FileReader();
imageReader.readAsDataURL(blob);
imageReader.onloadend = function() {
const b64Data = imageReader.result;
// Replace the widget with an <a> tag
widget.replaceWith(function() {
return $("<a>", {
id: widget.attr("id"),
class: widget.attr("class"),
style: widget.attr("style"),
alt: "Discord server widget",
href: inviteURL
});
});
// We need to grab the widget again to update it.
widget = $("#discord-compact-widget");
// Setup the CSS so that the image is displayed.
widget.css("display", "block");
widget.css("max-height", "76px");
widget.css("max-width", "320px");
// Create the image.
const widgetImage = document.createElement("img");
widgetImage.src = b64Data;
widgetImage.style.width = "100%";
widgetImage.style.height = "100%";
widgetImage.style.borderRadius = "5px";
widget.append(widgetImage);
// Prevent image dragging.
widget.on("dragstart", function(e) { e.preventDefault(); });
// We're done here.
console.log("DiscordCompact loaded successfully!");
}
});
});
});
/**
* based on https://dev.fandom.com/wiki/MediaWiki:DiscordIntegrator/code.js
*
* used by other wikis.
*/
$(function() {
'use strict';
var mconfig = mw.config.get([
'wgContentLanguage',
'wgUserLanguage',
'wgUserName'
]);
if (window.DiscordIntegratorLoaded) {
return;
}
window.DiscordIntegratorLoaded = true;
/**
* Main object
* @static
*/
var DiscordIntegrator = {
/**
* Initializing
*/
init: function() {
mw.hook('wikipage.content').add($.proxy(this.insertToContent, this));
},
/**
* Finding the designated places in content
* in which to place the widget and placing it
*/
insertToContent: function($content) {
$content.find('.DiscordIntegrator:not(.loaded)').each($.proxy(function(cabbage, el) {
el = $(el);
el.html(this.generateContent(el.data())).addClass('loaded');
}, this));
},
/**
* Determines the theme of the widget.
* @param {string} config Configured theme
* @return {string} 'light' or 'dark' depending on the wiki theme and configuration
*/
determineTheme: function(config) {
// If explicitly configured to light or dark.
if (config === 'dark') {
return 'dark';
}
if (config === 'light') {
return 'light';
}
/** If not configured **/
// try to determine based on wiki theme (set by themeToggle):
var clas = $(':root').attr('class');
var regex = /(^|\s)theme-(\w+)(\s|$)/;
var match = clas.match(regex);
if(match){
var wikiThemeName = match[2];
if(typeof(config) === 'object' && config !== null){ //with json theme config
if(config[wikiThemeName]){
return config[wikiThemeName];
}
}
if(wikiThemeName === 'light'){
return 'light';
}
if(wikiThemeName === 'dark'){
return 'dark';
}
}
// Otherwise, default to dark.
return 'dark';
},
/**
* Generating widget content from an object
* @return {string} Content of the widget
*/
generateContent: function(config) {
if (!config.id || !String(config.id).match(/\d{17,19}/)) {
return "Error: ID of the widget is malformed or not supplied, please see <a href='https://support.wiki.gg/wiki/DiscordWidget' title='the instructions'>the instructions</a> for how to find your server's ID. Please make sure you are not inserting <strong>the DiscordIntegrator template</strong> when asked for <strong>your widget ID</strong>.";
}
if (
(
config.loggedIn === true ||
Boolean(config['logged-in']) === true &&
config['logged-in'] !== 'false' &&
config['logged-in'] !== '{{{loggedIn}}}'
) && !mconfig.wgUserName
) {
return "Please <a href='/Special:UserLogin' title='log in'>log in</a> to see this widget.";
}
var username = config.username === '@disabled' ?
'' :
config.username === '@function' &&
typeof window.DiscordIntegratorGetUsername === 'function' ?
window.DiscordIntegratorGetUsername() :
config.username || mconfig.wgUserName;
return mw.html.element('iframe', {
src: 'https://discord.com/widget?id=' + config.id +
'&theme=' + this.determineTheme(config.theme) +
'&username=' + encodeURIComponent(username),
width: config.width || '100%',
height: config.height || '400px',
allowtransparency: 'true',
frameborder: '0',
title: "Discord server widget"
});
}
};
DiscordIntegrator.init();
});
1e1fd5704120cf67e15a757bd964c7295bdb464e
MediaWiki:Gadgets/luaImportLinks
8
263
287
2025-08-20T01:25:14Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [
828
],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.js"
],
"dependencies": [
"jquery"
],
"type": "general"
}
}
e5843d78effc2d04aa1fde18970885a1845ae525
MediaWiki:Gadgets/luaImportLinks/main.js
8
264
288
2025-08-20T01:25:14Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
/* Link to imported modules from Lua code */
$(function() {
var config = mw.config.get([
'wgCanonicalNamespace',
'wgFormattedNamespaces'
]);
if (config.wgCanonicalNamespace !== 'Module') {
return;
}
var localizedNamespace = config.wgFormattedNamespaces[828];
$('.s1, .s2, .s').each(function() {
var $this = $(this);
var html = $this.html();
var quote = html[0];
var isLongStringQuote = quote === '[';
var quoteRE = new RegExp('^\\' + quote + '|\\' + quote + '$', 'g');
if (isLongStringQuote) {
quoteRE = /^\[\[|\]\]$/g;
}
var name = html.replace(quoteRE, '');
var isEnglishPrefix = name.startsWith('Module:');
var isLocalizedPrefix = name.startsWith(localizedNamespace + ':');
var isDevPrefix = name.startsWith('Dev:');
if (isEnglishPrefix || isLocalizedPrefix || isDevPrefix) {
var attrs = {
href: mw.util.getUrl(name)
};
if (isDevPrefix) {
attrs.href = 'https://commons.wiki.gg/wiki/Module:' + mw.util.wikiUrlencode(name.replace('Dev:', ''));
attrs.target = '_blank';
attrs.rel = 'noopener';
}
var link = mw.html.element('a', attrs, name);
var str = quote + link + quote;
if (isLongStringQuote) {
str = '[[' + link + ']]';
}
$this.html(str);
}
});
});
dc09796545586723653a906ae1fed87411f49536
MediaWiki:Gadgets/spoilers/main.js
8
265
289
2025-08-20T01:25:15Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
/* [[Template:Spoiler]] */
mw.hook('wikipage.content').add(function() {
$('.spoiler-content')
.off('click') // in case this code is loaded twice
.on('click', function(e){
$(this).toggleClass('show');
}).find('a').on('click', function(e){
e.stopPropagation();
});
});
/* End Template:Spoiler */
c96e5a798a1781287a56037db79ab9094a3eae2b
MediaWiki:Gadgets/spoilers
8
266
290
2025-08-20T01:25:16Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [
"Pages with spoilers"
],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.js"
],
"dependencies": [
"jquery"
],
"type": "general"
}
}
e2aacbae968c704385f3937e6b0004f263907193
MediaWiki:Gadgets/charInserts
8
267
291
2025-08-20T01:25:16Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [
"edit"
],
"categories": [],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.js"
],
"dependencies": [
"jquery"
],
"type": "general"
}
}
518bbdc62f3fe767736f2de6ee9ba2b7eb9ab0a8
MediaWiki:Gadgets/charInserts/main.js
8
268
292
2025-08-20T01:25:17Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
$(function() {
$('.mw-charinsert-item').each(function() {
$(this).text($(this).closest('div').attr('data-ci-label'));
$(this).css('display', 'inline-block');
});
$('.ci-loading-text').css('display','none');
});
daabc4b17b7729432f5c146630a0715a7abc13e9
MediaWiki:Gadgets/themeColorEditor
8
269
293
2025-08-20T01:25:18Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [
8
],
"contentModels": [
"css"
],
"rights": [
"editinterface"
]
},
"module": {
"pages": [
"main.js"
],
"dependencies": [],
"type": "general"
}
}
b512452ab2c0b2fd4d86d6a70c4c80fba41d14ed
MediaWiki:Gadgets/themeColorEditor/main.js
8
270
294
2025-08-20T01:25:18Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
$(function() {
if (mw.config.get('wgPageName') != "MediaWiki:Common.css") return;
mw.loader.load( 'https://commons.wiki.gg/load.php?lang=en&modules=ext.gadget.themeColorEditorScript&skin=vector&maxage=360&smaxage=360' )
});
a6d1c6789815c3c323c2afd84def2c1ca23d5efe
MediaWiki:Gadgets/ranger/variables.css
8
271
295
2025-08-20T01:25:19Z
ARTIFICER
564804
Importing default loadout
css
text/css
.ranger-navbox{
--navbox-background: var(--wiki-content-background-color); /* for entire navbox */
--navbox-margin: 0.5em auto;
--navbox-padding: 4px;
--navbox-gap: 3px; /* when using zero-value, it must be 0px */
--navbox-outer-border-color: var(--wiki-content-border-color--accent);
--navbox-outer-border-width: 1px;
--navbox-outer-border-style: solid;
--navbox-outer-border-radius: 0px;
--navbox-font-size: calc(1em - 2px);
--navbox-title-color: var(--wiki-accent-label-color);
--navbox-title-font-size: calc(125%);
--navbox-title-background: var(--wiki-accent-color);
--navbox-title-icon-color: var(--wiki-accent-label-color);
--navbox-title-link-color: var(--navbox-title-color);
--navbox-title-link-color--visited: var(--navbox-title-link-color);
--navbox-title-link-color--hover: var(--wiki-accent-link-color);
--navbox-title-redlink-color: var(--navbox-title-link-color);
--navbox-title-link-decoration: underline solid;
--navbox-title-redlink-decoration: underline wavy;
--navbox-title-padding--y: 0.5em;
--navbox-above-background: color-mix(in srgb, var(--wiki-content-text-color) 15%, transparent);
--navbox-above-color: var(--wiki-content-text-color);
--navbox-above-padding: var(--navbox-list-padding);
--navbox-below-background: var(--navbox-above-background);
--navbox-below-color: var(--navbox-above-color);
--navbox-below-padding: var(--navbox-above-padding);
--navbox-header-color: var(--navbox-title-color);
--navbox-header-font-size: calc(110%);
--navbox-header-background: var(--navbox-title-background);
--navbox-header-icon-color: var(--navbox-title-icon-color);
--navbox-header-link-color: var(--navbox-title-link-color);
--navbox-header-link-color--visited: var(--navbox-title-link-color--visited);
--navbox-header-link-color--hover: var(--navbox-title-link-color--hover);
--navbox-header-redlink-color: var(--navbox-title-redlink-color);
--navbox-header-link-decoration: var(--navbox-title-link-decoration);
--navbox-header-redlink-decoration: var(--navbox-title-redlink-decoration);
--navbox-header-padding--y: 0.3em;
--navbox-subheader-font-size: calc(100%);
--navbox-subheader-padding--y: calc(var(--navbox-header-padding--y)/2);
--navbox-list-background: color-mix(in srgb, var(--wiki-content-text-color) 5%, transparent);
--navbox-list-background--striped: color-mix(in srgb, var(--wiki-content-text-color) 8%, transparent);
--navbox-list-color: var(--wiki-content-text-color);
--navbox-list-padding: 0.25em 0.5em;
/* --navbox-group-* also apply to .ranger-subgroup */
--navbox-group-text-align: left;
--navbox-group-text-align--mobile: left; /* only for mobile view */
--navbox-group-background: color-mix(in srgb, var(--wiki-accent-color) 20%, transparent);
--navbox-group-color: var(--wiki-content-text-color);
--navbox-group-padding: var(--navbox-list-padding);
--navbox-tree-line-color: color-mix(in srgb, var(--wiki-accent-color) 30%, transparent);
--navbox-tree-line-width: 2px;
--navbox-tree-indent: 1em;
--navbox-tree-line-indent: 0.5em;
--navbox-tree-line-spacing: var(--navbox-gap);
--icon-chevron-down: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' class='icon icon-tabler icon-tabler-chevron-down' width='24' height='24' viewBox='0 0 24 24' stroke-width='2' stroke='currentColor' fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'%3E%3C/path%3E%3Cpath d='M6 9l6 6l6 -6'%3E%3C/path%3E%3C/svg%3E");
--icon-metalinks: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' class='icon icon-tabler icon-tabler-edit' width='24' height='24' viewBox='0 0 24 24' stroke-width='2' stroke='currentColor' fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'%3E%3C/path%3E%3Cpath d='M7 7h-1a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-1'%3E%3C/path%3E%3Cpath d='M20.385 6.585a2.1 2.1 0 0 0 -2.97 -2.97l-8.415 8.385v3h3l8.385 -8.415z'%3E%3C/path%3E%3Cpath d='M16 5l3 3'%3E%3C/path%3E%3C/svg%3E");
--navbox-icon-offset--x: 0.5rem; /* should be an absolute length (rem-based or px-based) */
}
.ranger-navbox.pill,
.ranger-navbox.pill-mobile{
/** vars for the "pill" style only (`.pill` and ".pill-mobile" clases) **/
--navbox-pill-gap: 0.3em;
--navbox-pill-padding: 0.25em 0.75em;
--navbox-pill-border-radius: 3px;
--navbox-pill-box-shadow: none;
--navbox-pill-background: color-mix(in srgb, var(--wiki-content-text-color) 5%, transparent);
--navbox-pill-box-shadow--hover: inset 0 0 3px var(--navbox-list-color);
--navbox-pill-background--hover: var(--navbox-pill-background);
--navbox-pill-selflink-background: color-mix(in srgb, var(--wiki-accent-color) 15%, transparent);/* background of pills with selflink in them */
/* remove list cell background */
--navbox-list-background: none;
--navbox-list-background--striped: color-mix(in srgb, var(--wiki-content-text-color) 3%, transparent);
}
.ranger-navbox.no-underline-title-links{
--navbox-title-link-color: var(--wiki-accent-link-color);
--navbox-title-link-decoration: none;
--navbox-title-redlink-decoration: none;
}
.ranger-navbox.noborder,
.ranger-navbox.no-border{
--navbox-padding: 0px;
--navbox-outer-border-width: 0px;
}
/******************************
* Fallback for older browsers *
*******************************/
@supports not (color:color-mix(in srgb, #000, transparent)) {
.ranger-navbox {
--navbox-above-background: var(--wiki-content-background-color--secondary);
--navbox-list-background: transparent;
--navbox-list-background--striped: var(--wiki-content-background-color--secondary);
--navbox-group-background: var(--wiki-content-background-color--secondary);
--navbox-tree-line-color: var(--wiki-content-background-color--secondary);
}
.ranger-navbox.pill,
.ranger-navbox.pill-mobile {
--navbox-pill-background: var(--wiki-content-background-color--secondary);
--navbox-list-background--striped: transparent;
--navbox-pill-selflink-background: var(--wiki-content-background-color--secondary);
}
}
/***************
* End fallback *
****************/
0f49887270380cdac6968f16cfc75a115818c39a
MediaWiki:Gadgets/hoverShowSpoilers
8
272
296
2025-08-20T01:25:19Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": false,
"default": false,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [
"Pages with spoilers"
],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.css"
],
"dependencies": [],
"type": "styles"
}
}
427adff0005c5bf986f2bca5bf83943f65359867
MediaWiki:Gadgets/mpEditLinks
8
273
297
2025-08-20T01:25:20Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [],
"contentModels": [],
"rights": [
"editprotected"
]
},
"module": {
"pages": [
"main.css",
"main.js"
],
"messages": [
"gadget-mpEditLinks-edit-link-text",
"gadget-mpEditLinks-toggle-link-text"
],
"dependencies": [
"jquery",
"mediawiki.jqueryMsg",
"mediawiki.util"
],
"type": "general"
}
}
a6733e82425fccced50edfeace86534103f0424b
MediaWiki:Gadgets/collapsibleSidebarSections
8
274
298
2025-08-20T01:25:21Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "appearance",
"package": true,
"default": false,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.css",
"main.js"
],
"dependencies": [
"jquery"
],
"type": "general"
}
}
d67dc8fabaf4e1d275a3b17c42f3d707f00b707c
MediaWiki:Gadgets/collapsibleSidebarSections/main.js
8
275
299
2025-08-20T01:25:21Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
$(function(){
// CONFIG section, you can edit this part
// a list of sections that should be collapsed by default for *all users*.
// This should be the name of the heading as listed in Mediawiki:Sidebar and is case-sensitive.
// For example, if you have '* Character_Classes' and you want that section collapsed, add 'Character_Classes' into the brackets below.
// Separate entries with commas and use underscores instead of spaces.
// Example list: ['Character_Classes', 'Items', 'External_Links']
// Please DO NOT add navigation or tb into this list, as they are expected functionality.
var INITIALLY_COLLAPSED_IDS = [];
var MIN_ACTIVATION_WIDTH = 721;
//END CONFIG
// add the p- onto ids for ease of use, if not present
INITIALLY_COLLAPSED_IDS.forEach(function(id, index){
if(!id.startsWith('p-')){
INITIALLY_COLLAPSED_IDS[index] = 'p-' + id;
}
});
var $portals = $("#mw-panel .vector-menu-portal");
var setup = function(){
$portals.each(function(index, el){
if(window.innerWidth < MIN_ACTIVATION_WIDTH) {
return;
}
var $el = $(el);
var $id = $el.attr("id");
if(!$id){
return;
}
// check if this portal should be collapsed
if(
// portal is set to be initially collapsed and user has not indicated that they want it open
(INITIALLY_COLLAPSED_IDS.includes($id) && localStorage.getItem('sidebar_c_'+$id) != "n")
|| // or
// user has indicated they want this portal collapsed
(localStorage.getItem('sidebar_c_'+$id) === "y")
){
$el.addClass('collapsed').find('.vector-menu-content').slideUp(0);
}
});
}
setup();
$(window).on('resize', setup);
$portals.on("click", "h3", function(event){
if(window.innerWidth < MIN_ACTIVATION_WIDTH) {
return;
}
var $el = $(this).parent();
var $id = $el.attr("id");
if(!$id){
return;
}
$el.toggleClass('collapsed');
if($el.hasClass('collapsed')){ // more consistent between class and slide status.
localStorage.setItem('sidebar_c_'+$id, "y");
$el.find('.vector-menu-content').slideUp('fast');
}
else{
localStorage.setItem('sidebar_c_'+$id, "n");
$el.find('.vector-menu-content').slideDown('fast');
}
});
});
63d4425138f9c81e8294fbd01a08de9e1f58256a
MediaWiki:Gadgets/collapsibleSidebarSections/main.css
8
276
300
2025-08-20T01:25:22Z
ARTIFICER
564804
Importing default loadout
css
text/css
@media screen and (min-width: 721px) {
.client-js #mw-panel .portal:not(#p-ext-discordwidget) .vector-menu-heading {
cursor: pointer;
display: flex;
align-items: center;
justify-content: space-between;
transition: all 0.2s;
}
.client-js #mw-panel .portal:not(#p-ext-discordwidget) .vector-menu-heading::after {
content: "";
display: block;
pointer-events: none;
width: 1em;
height: 1em;
margin-top: 1px; /* offset */
--mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' class='icon icon-tabler icon-tabler-chevron-down' width='24' height='24' viewBox='0 0 24 24' stroke-width='2' stroke='currentColor' fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'%3E%3C/path%3E%3Cpath d='M6 9l6 6l6 -6'%3E%3C/path%3E%3C/svg%3E") no-repeat;
-webkit-mask: var(--mask);
mask: var(--mask);
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
-webkit-mask-position: center center;
mask-position: center center;
background-color: var(--wiki-sidebar-heading-color, var(--wiki-sidebar-link-color));
transform: rotate(180deg);
}
.client-js #mw-panel .portal:not(#p-ext-discordwidget).collapsed .vector-menu-heading::after {
transform: rotate(0deg);
}
.client-js #mw-panel .vector-menu-portal.collapsed .vector-menu-heading {
margin-bottom: 0;
}
}
5ab6f9e9146615a8038e81b9990004fdb06e00c0
MediaWiki:Gadgets/uploadMultipleFiles
8
277
301
2025-08-20T01:25:23Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [
-1
],
"contentModels": [],
"rights": [
"edit",
"upload"
]
},
"module": {
"pages": [
"main.js"
],
"dependencies": [
"jquery",
"mediawiki.util"
],
"type": "general"
}
}
13bc1e984c367575a7b4f4ac29d2cf75b4f01c6c
MediaWiki:Gadgets/purge
8
278
302
2025-08-20T01:25:23Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [],
"contentModels": [],
"rights": [
"edit"
]
},
"module": {
"pages": [
"main.js"
],
"messages": [
"cargo-purgecache",
"cargo-purgecache-failed",
"action-purge"
],
"dependencies": [
"mediawiki.util",
"mediawiki.api",
"mediawiki.jqueryMsg"
],
"type": "general"
}
}
ebb5f4bfef49746bef46514b0ffaccee57f3f1cd
MediaWiki:Gadgets/ranger/custom.css
8
279
303
2025-08-20T01:25:24Z
ARTIFICER
564804
Importing default loadout
css
text/css
/* Custom RANGER styles can go here. Rules here will override rules of equal specificity in main.css */
769d3248cef93d2b58dcf7339da923494f5173f8
MediaWiki:Gadgets/vectorScripts
8
280
304
2025-08-20T01:25:24Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": true,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [],
"contentModels": [],
"rights": [],
"skins": [
"vector"
]
},
"module": {
"pages": [
"main.js"
],
"dependencies": [],
"type": "general"
}
}
f26fca963d213febee869477a05933a6fedfc542
MediaWiki:Gadgets/vectorScripts/main.js
8
281
305
2025-08-20T01:25:25Z
ARTIFICER
564804
Importing default loadout
javascript
text/javascript
/*** Mobile navigation toggle button ***/
( function () {
const BUTTON_CLASS = 'mobile-nav-toggle';
const EXPANDED_CLASS = 'nav--expanded';
if (document.querySelector('button.' + BUTTON_CLASS)){return;} // early return to avoid double button if this runs twice
let mobileSidebarButton = document.createElement( 'button' );
let sidebar = document.getElementById( 'mw-panel' );
mobileSidebarButton.className = BUTTON_CLASS;
mobileSidebarButton.addEventListener( 'click', function () {
mobileSidebarButton.classList.toggle( EXPANDED_CLASS );
sidebar.classList.toggle( EXPANDED_CLASS );
} );
sidebar.prepend( mobileSidebarButton );
document.body.classList.add( 'has-vector-mobile-menu' );
} )();
/*** End mobile navigation toggle button ***/
/*** #mw-head collapsing fix ***/
/*** IMPORTANT: Do not copy this code if your wiki is not updated to default loadout 2.0 (May 22, 2025) or later, or your navigation tabs will break ***/
mw.loader.using('skins.vector.legacy.js', function() {
$.collapsibleTabs.calculateTabDistance = function(){
return parseInt(window.getComputedStyle(document.getElementById( 'right-navigation' ), '::before').width ) - 1;
}
});
/*** END #mw-head collapsing fix ***/
cb209a13dfc674d9ad471ec79784c4d65ad785f1
MediaWiki:Gadgets/userProfile
8
282
306
2025-08-20T01:25:26Z
ARTIFICER
564804
Importing default loadout
GadgetDefinition
application/json
{
"settings": {
"section": "",
"package": true,
"default": true,
"hidden": false,
"supportsUrlLoad": false
},
"loadConditions": {
"actions": [],
"categories": [],
"namespaces": [
-1,
2,
3
],
"contentModels": [],
"rights": []
},
"module": {
"pages": [
"main.js",
"main.css"
],
"dependencies": [
"mediawiki.interface.helpers.styles",
"mediawiki.util",
"mediawiki.api",
"jquery"
],
"type": "general"
}
}
e9c76b459199205abae5373548f6ff36e83fefcc
File:Site-favicon.ico
6
283
307
2025-08-20T23:13:27Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|game}}
5fdc0517c60eec1aa02a1fef9763fa88c38be9ad
308
307
2025-08-20T23:14:46Z
Sharparam
284703
Protected "[[File:Site-favicon.ico]]": Favicon used for the entire site ([Edit=Allow only users with a confirmed email address] (indefinite) [Rename=Allow only administrators] (indefinite) [Upload=Allow only administrators] (indefinite))
wikitext
text/x-wiki
== Licensing ==
{{License|game}}
5fdc0517c60eec1aa02a1fef9763fa88c38be9ad
File:Site-logo.png
6
284
309
2025-08-20T23:16:37Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|game}}
5fdc0517c60eec1aa02a1fef9763fa88c38be9ad
310
309
2025-08-20T23:17:03Z
Sharparam
284703
Protected "[[File:Site-logo.png]]": Logo for the whole wiki ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite) [Upload=Allow only administrators] (indefinite))
wikitext
text/x-wiki
== Licensing ==
{{License|game}}
5fdc0517c60eec1aa02a1fef9763fa88c38be9ad
Template:Navbox/Items
10
285
323
322
2025-08-20T23:22:44Z
Sharparam
284703
12 revisions imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Essential items|Essential]]
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group1.1 = [[Upgrade items|Upgrade]]
| list1.1 =
* [[Upgrade Splinter]]
* [[Upgrade Module]]
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
7ddddd74185f43622c0032fb924e9ea4df3f2c1d
Template:Navbox/Consumables
10
286
330
329
2025-08-20T23:22:44Z
Sharparam
284703
6 revisions imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
| group2 = Fluids
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
* [[Restorative Fluid]]
| group3 = Concoctions
| list3 =
* [[Diver's Lungs Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
* [[Concoction: Zealot's Tears]]
* [[Experience Concoction]]
* [[Mystery Concoction]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
e9736a1ea6833ecda5952ac6a85bce948c9cf19a
Template:Navbox/Capes
10
287
336
335
2025-08-20T23:22:44Z
Sharparam
284703
5 revisions imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Capes
| title = [[Capes]]
| list1 =
* [[Agile Cape]]
* [[Corrupted Cape]]
* [[Folk Cape]]
* [[Fur Cape]]
* [[Ronin Scarf]]
* [[Sentinel Overcoat]]
* [[Spectre Scarf]]
* [[Tattered Cape]]
* [[Techpriest Cape]]
* [[Traveler Cape]]
* [[Wanderer Cape]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
25d3fe6cdc6b4cce6fe483d3b4b7218599b53b34
Template:Navbox/Anomalous crystals
10
288
339
338
2025-08-20T23:22:44Z
Sharparam
284703
2 revisions imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Anomalous crystals
| title = [[Anomalous crystals]]
| list1=
* [[Lesser Anomalous Crystal]]
* [[Anomalous Crystal]]
* [[Greater Anomalous Crystal]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ebedb2789af69363588ddf5553b8868dcbf7005d
Template:Navbox/Lore
10
289
344
343
2025-08-20T23:22:45Z
Sharparam
284703
4 revisions imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Lore
| title = [[Lore]]
| group1 = [[Data logs]]
| list1 = {{Navbox/Data logs|child}}
| group2 = [[Documents]]
| list2 = {{Navbox/Documents|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
cc386cacfb50aa464ec9e6065463991e75c6ef65
Template:Navbox/Data logs
10
290
367
366
2025-08-20T23:22:45Z
Sharparam
284703
22 revisions imported: Import from private test wiki
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[A Broken Reality]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[Understanding]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
09b921cd27b38e22701e9064c302db0e3c8d90f3
Template:Navbox/Documents
10
291
369
368
2025-08-20T23:22:45Z
Sharparam
284703
1 revision imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Documents
| title = [[Documents]]
| list1 =
* [[Konrad's War Log]]
* [[Helena's Diary Fragment]]
* [[Hellicar's Maxims]]
* [[Guiscard's Manifest]]
* [[Untitled Log]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
4859742a1634980b598ee96ab98cf1b44828e159
Template:Navbox/Rings
10
292
376
375
2025-08-20T23:22:46Z
Sharparam
284703
6 revisions imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
* [[Ring of Hawk]]
* [[Ring of Rammstein]]
* [[Ring of Lesser Talent]]
* [[Ring of Talent]]
* [[Ring of Exceeding Talent]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
a26fb4e5bb5097e037bde34bbe50c7f6f0fd3453
Template:Navbox/Locations
10
293
383
382
2025-08-20T23:22:46Z
Sharparam
284703
6 revisions imported: Import from private test wiki
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]] ([[Monastery#Lower|Lower]] · [[Monastery#Upper|Upper]])
* [[Blok 6147]]
* [[Rain District]] ([[Rain District#Sewers|Sewers]] · [[Rain District#Center|Center]])
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]] ([[Uranopolis#Tower Complex|Tower Complex]] · [[Uranopolis#Lone Tower|Lone Tower]])
* [[Ghost Town]] ([[Ghost Town#Floor 13|Floor 13]] · [[Ghost Town#Floor 1|Floor 1]])
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
* [[Unknown (location)|Unknown]]
* [[Vermillion Fields]] ([[Vermillion Fields#Plaza|Plaza]] · [[Vermillion Fields#Temple|Temple]])
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
7716644faea4dd5aee763d21d89daca0de53c69c
Template:Navbox/NPCs
10
294
385
384
2025-08-20T23:22:46Z
Sharparam
284703
1 revision imported: Import from private test wiki
wikitext
text/x-wiki
{{Navbox
| {{{child|}}}
| template = Navbox/NPCs
| title = [[NPCs]]
| list1 =
* [[Abandoned Soldier]]
* [[Abelard the Brave]]
* [[Anselm the Pure]]
* [[Archinquisitor Belisarius]]
* [[The Handler]]
* [[Inquisitor Commander Alexius]]
* [[Mysterious Woman]]
* [[Royal Division Captain Yulia]]
* [[Stranger]]
* [[Yaroslav]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
<noinclude>
19819092a7dffc936dc5330f6d3c7764bede86db
User:Sharparam
2
295
386
2025-08-20T23:25:19Z
Sharparam
284703
Created page with "{{#invoke:infobox|main | title = Sharparam | image = [[File:Sharparam.png|300px|link=]] | sections = Basic Info,Socials | Basic Info = Pronouns, Website | Pronouns = He/Him or They/Them | Website = [https://sharparam.com sharparam.com] | Socials = GitHub, Reddit, Discord | Socials_columns = 3 | GitHub = [https://github.com/Sharparam Sharparam] | Reddit = [https://reddit.com/u/Sharparam Sharparam] | Discord = sharparam }} Hello, I am '''Sharparam'''! I use my /sandbox..."
wikitext
text/x-wiki
{{#invoke:infobox|main
| title = Sharparam
| image = [[File:Sharparam.png|300px|link=]]
| sections = Basic Info,Socials
| Basic Info = Pronouns, Website
| Pronouns = He/Him or They/Them
| Website = [https://sharparam.com sharparam.com]
| Socials = GitHub, Reddit, Discord
| Socials_columns = 3
| GitHub = [https://github.com/Sharparam Sharparam]
| Reddit = [https://reddit.com/u/Sharparam Sharparam]
| Discord = sharparam
}}
Hello, I am '''Sharparam'''!
I use my [[/sandbox|sandbox]] to test stuff.
== Data mining ==
The results of my data mining attempts can be found in a [https://drive.google.com/drive/folders/1UXX_9w59D19ZmgBzf_bN6tIHxZuyJdWx?usp=sharing Shared GDrive folder].
== My user styles and scripts ==
=== Styles ===
* [[/common.css]]
=== Scripts ===
* [[/common.js]]
== MediaWiki "bookmarks" ==
* [[MediaWiki:Common.css]]
* [[MediaWiki:Vector.css]]
735978aec72a43447f01b77eefc887f01ca6ee63
Bleak Faith: Forsaken Wiki/external
0
8
387
15
2025-08-20T23:30:01Z
Sharparam
284703
Replace example links with Bleak Faith links
wikitext
text/x-wiki
{{Main page box/start
| title = External links
}}
<div class="mp-links columns-2">
* {{MP link|Official site|link=http://www.bleakfaith.com/}}
* {{MP link|Discord|link=https://discord.com/invite/x7UCRbHAAq|image=Discord.svg|size=64x64px}}
* {{MP link|Reddit|link=https://www.reddit.com/r/Bleak_Faith/|image=Reddit.svg|size=64x64px}}
* {{MP link|Steam|link=https://store.steampowered.com/app/1173220/Bleak_Faith_Forsaken/|image=Steam.svg|size=64x64px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
5bd796659a5bafa38b5bab3f000fecaaeaa472aa
Module:Coordinates
828
296
388
2025-08-21T14:51:06Z
Sharparam
284703
Created page with "local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$" local NS_TO_CATEGORISE = { [0] = true, -- main [6] = true, -- file [14] = true -- category } local args_util = require('Module:ArgsUtil') local p = {} ---@param val number ---@param label string local function coordNode(val, label) return mw.html.create('span') :addClass(label) :wikitext(p.formatCoord(val)) end ---@param val number ---@return string function p.formatCoord(val) local sign = val < 0 and '-' or ''..."
Scribunto
text/plain
local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$"
local NS_TO_CATEGORISE = {
[0] = true, -- main
[6] = true, -- file
[14] = true -- category
}
local args_util = require('Module:ArgsUtil')
local p = {}
---@param val number
---@param label string
local function coordNode(val, label)
return mw.html.create('span')
:addClass(label)
:wikitext(p.formatCoord(val))
end
---@param val number
---@return string
function p.formatCoord(val)
local sign = val < 0 and '-' or ''
val = math.abs(val)
val = math.floor(val * 100) / 100
local str = tostring(val)
local int = string.match(str, "^%d+")
local dec = string.match(str, "%.(%d-)0*$") or ''
local int_len = #int
local dec_len = #dec
if int_len >= 3 then
return sign .. string.sub(int, 1, 4)
end
if dec_len == 0 then return sign .. int end
return string.format("%s%s.%s", sign, int, string.sub(dec, 1, int_len == 2 and 1 or 2))
end
function p.main(frame)
local args = args_util.merge()
return p._main(args)
end
function p._main(args)
local x = tonumber(args.x or args[1]) or 0
local y = tonumber(args.y or args[2]) or 0
local z = tonumber(args.z or args[3]) or 0
local xdec = string.sub(tostring(math.fmod(x, 1)), 3)
local ydec = string.sub(tostring(math.fmod(y, 1)), 3)
local zdec = string.sub(tostring(math.fmod(z, 1)), 3)
local inaccurate = #xdec ~= 2 or #ydec ~= 2 or #zdec ~= 2
local tooltip = string.format("X: %d, Y: %d, Z: %d", x, y, z)
local elem = mw.html.create('span')
:css('border-bottom', '1px dotted')
:attr('data-x', x)
:attr('data-y', y)
:attr('data-z', z)
:attr('title', tooltip)
:addClass('coordinates')
:addClass('nowrap')
:node(coordNode(x, 'x'))
:wikitext('::')
:node(coordNode(y, 'y'))
:wikitext('::')
:node(coordNode(z, 'z'))
elem = tostring(elem)
local ns = mw.title.getCurrentTitle().namespace
if NS_TO_CATEGORISE[ns] then
if inaccurate then
elem = elem .. '[[Category:Pages with inaccurate coordinates]]'
end
elem = elem .. '[[Category:Pages with coordinates]]'
end
return elem
end
return p
de47bf0e464009651055c19beae22b5024ae6aa3
397
388
2025-08-21T14:59:20Z
Sharparam
284703
Fix tooltip display not showing decimals
Scribunto
text/plain
local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$"
local NS_TO_CATEGORISE = {
[0] = true, -- main
[6] = true, -- file
[14] = true -- category
}
local args_util = require('Module:ArgsUtil')
local p = {}
---@param val number
---@param label string
local function coordNode(val, label)
return mw.html.create('span')
:addClass(label)
:wikitext(p.formatCoord(val))
end
---@param val number
---@return string
function p.formatCoord(val)
local sign = val < 0 and '-' or ''
val = math.abs(val)
val = math.floor(val * 100) / 100
local str = tostring(val)
local int = string.match(str, "^%d+")
local dec = string.match(str, "%.(%d-)0*$") or ''
local int_len = #int
local dec_len = #dec
if int_len >= 3 then
return sign .. string.sub(int, 1, 4)
end
if dec_len == 0 then return sign .. int end
return string.format("%s%s.%s", sign, int, string.sub(dec, 1, int_len == 2 and 1 or 2))
end
function p.main(frame)
local args = args_util.merge()
return p._main(args)
end
function p._main(args)
local x = tonumber(args.x or args[1]) or 0
local y = tonumber(args.y or args[2]) or 0
local z = tonumber(args.z or args[3]) or 0
local xdec = string.sub(tostring(math.fmod(x, 1)), 3)
local ydec = string.sub(tostring(math.fmod(y, 1)), 3)
local zdec = string.sub(tostring(math.fmod(z, 1)), 3)
local inaccurate = #xdec ~= 2 or #ydec ~= 2 or #zdec ~= 2
local tooltip = string.format("X: %.1f, Y: %.1f, Z: %.1f", x, y, z)
local elem = mw.html.create('span')
:css('border-bottom', '1px dotted')
:attr('data-x', x)
:attr('data-y', y)
:attr('data-z', z)
:attr('title', tooltip)
:addClass('coordinates')
:addClass('nowrap')
:node(coordNode(x, 'x'))
:wikitext('::')
:node(coordNode(y, 'y'))
:wikitext('::')
:node(coordNode(z, 'z'))
elem = tostring(elem)
local ns = mw.title.getCurrentTitle().namespace
if NS_TO_CATEGORISE[ns] then
if inaccurate then
elem = elem .. '[[Category:Pages with inaccurate coordinates]]'
end
elem = elem .. '[[Category:Pages with coordinates]]'
end
return elem
end
return p
2e9e52b2c3ce3d680e6c156a74e9794100f9de20
Template:Coordinates
10
297
389
2025-08-21T14:52:10Z
Sharparam
284703
Created page with "{{#invoke:Coordinates|main}}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#invoke:Coordinates|main}}<noinclude>{{Documentation}}</noinclude>
f6c5bc6a93e6c91ac2daccb423e3ca4e2e61b94f
Template:Coordinates/doc
10
298
390
2025-08-21T14:52:43Z
Sharparam
284703
Created page with "This template uses the {{ml|Coordinates}} Lua module. == Usage == <templatedata> { "params": { "x": { "aliases": [ "1" ], "label": "X", "description": "X coordinate", "example": "52", "type": "number", "required": true }, "y": { "aliases": [ "2" ], "label": "Y", "description": "Y coordinate", "example": "12.5", "type": "number", "required": true }, "z": { "aliases": [ "3" ], "label": "Z", "des..."
wikitext
text/x-wiki
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.5",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.6",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12|y=50|z=-32}}</syntaxhighlight> → {{Coordinates|x=12|y=50|z=-32}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.5|42.5|-4.4}}</syntaxhighlight> → {{Coordinates|16.5|42.5|-4.4}}
0374227811c51975a2c4f372bfd6877f1362368f
396
390
2025-08-21T14:56:54Z
Sharparam
284703
Add some shorthand examples
wikitext
text/x-wiki
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.5",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.6",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12|y=50|z=-32}}</syntaxhighlight> → {{Coordinates|x=12|y=50|z=-32}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.5|42.5|-4.4}}</syntaxhighlight> → {{Coordinates|16.5|42.5|-4.4}}
* <syntaxhighlight lang="wikitext" inline>{{coords|1.2|3.4|5.6}}</syntaxhighlight> → {{coords|1.2|3.4|5.6}}
* <syntaxhighlight lang="wikitext" inline>{{pos|6.5|4.3|2.1}}</syntaxhighlight> → {{pos|6.5|4.3|2.1}}
7af2ee703d6da0280470b4042899b8ff0fbb5115
Template:Coords
10
299
391
2025-08-21T14:53:49Z
Sharparam
284703
Redirected page to [[Template:Coordinates]]
wikitext
text/x-wiki
#REDIRECT [[Template:Coordinates]]
b5be2dd4498d085b3d37c3f6a8be85ba839892d5
Template:Position
10
300
392
2025-08-21T14:54:07Z
Sharparam
284703
Redirected page to [[Template:Coordinates]]
wikitext
text/x-wiki
#REDIRECT [[Template:Coordinates]]
b5be2dd4498d085b3d37c3f6a8be85ba839892d5
Template:Pos
10
301
393
2025-08-21T14:54:26Z
Sharparam
284703
Redirected page to [[Template:Coordinates]]
wikitext
text/x-wiki
#REDIRECT [[Template:Coordinates]]
b5be2dd4498d085b3d37c3f6a8be85ba839892d5
Template:Coord
10
302
394
2025-08-21T14:54:43Z
Sharparam
284703
Redirected page to [[Template:Coordinates]]
wikitext
text/x-wiki
#REDIRECT [[Template:Coordinates]]
b5be2dd4498d085b3d37c3f6a8be85ba839892d5
Template:Coordinate
10
303
395
2025-08-21T14:55:03Z
Sharparam
284703
Redirected page to [[Template:Coordinates]]
wikitext
text/x-wiki
#REDIRECT [[Template:Coordinates]]
b5be2dd4498d085b3d37c3f6a8be85ba839892d5
Template:Yesno
10
304
398
2025-08-21T15:10:37Z
Sharparam
284703
Created page with "{{<includeonly>safesubst:</includeonly>#switch: {{<includeonly>safesubst:</includeonly>lc: {{{1|¬}}} }} |no |n |false |0 = {{{no|<!-- null -->}}} | = {{{blank|{{{no|<!-- null -->}}}}}} |¬ = {{{¬|}}} |yes |y |true |1 = {{{yes|yes}}} |#default = {{{def|{{{yes|yes}}}}}} }}<noinclude> {{Documentation}} </noinclude>"
wikitext
text/x-wiki
{{<includeonly>safesubst:</includeonly>#switch: {{<includeonly>safesubst:</includeonly>lc: {{{1|¬}}} }}
|no
|n
|false
|0 = {{{no|<!-- null -->}}}
| = {{{blank|{{{no|<!-- null -->}}}}}}
|¬ = {{{¬|}}}
|yes
|y
|true
|1 = {{{yes|yes}}}
|#default = {{{def|{{{yes|yes}}}}}}
}}<noinclude>
{{Documentation}}
</noinclude>
166fab9e5411aacd02ca4c9e93fbc7bf6bcf26ac
Template:Sandbox other
10
305
399
2025-08-21T15:22:25Z
Sharparam
284703
Created page with "{{#switch:{{SUBPAGENAME}}|sandbox|doc={{{1|}}}|#default={{{2|}}}}}<noinclude> {{documentation}} </noinclude>"
wikitext
text/x-wiki
{{#switch:{{SUBPAGENAME}}|sandbox|doc={{{1|}}}|#default={{{2|}}}}}<noinclude>
{{documentation}}
</noinclude>
278877c2ad3ab9f7df5d91845dc67d2f4e2c6a46
Template:Sandbox other/doc
10
306
400
2025-08-21T15:23:28Z
Sharparam
284703
Created page with "<!-- {{Documentation subpage}} --> <!-- Categories go at the bottom of this page and interwikis go in Wikidata. --> <templatedata> { "description": { "en": "This template displays different output on sandbox and documentation pages than other ones." }, "params": { "1": { "label": { "en": "Sandbox text" }, "description": { "en": "Text displayed on sandbox (/sandbox) and documentation (/doc) subpages. Usually this doesn’t contain categories, but i..."
wikitext
text/x-wiki
<!-- {{Documentation subpage}} -->
<!-- Categories go at the bottom of this page and interwikis go in Wikidata. -->
<templatedata>
{
"description": {
"en": "This template displays different output on sandbox and documentation pages than other ones."
},
"params": {
"1": {
"label": {
"en": "Sandbox text"
},
"description": {
"en": "Text displayed on sandbox (/sandbox) and documentation (/doc) subpages. Usually this doesn’t contain categories, but it may contain a link to the main template."
},
"type": "content",
"suggested": true
},
"2": {
"label": {
"en": "Normal text"
},
"description": {
"en": "Text displayed everywhere except for sandbox and documentation subpages. Usually this contains categories for the template."
},
"type": "content",
"suggested": true
}
}
}
</templatedata>
<includeonly>{{#ifeq:{{SUBPAGENAME}}|sandbox||
<!-- Categories go here and interwikis go in Wikidata. -->
[[Category:Templates]]
}}</includeonly>
d4d9f60bd1d1c7555fdc8529a0039406cfd26726
Template:Yesno/doc
10
307
401
2025-08-21T15:23:49Z
Sharparam
284703
Created page with "<!-- {{Documentation subpage}} --> <!-- PLEASE ADD CATEGORIES AND INTERWIKIS AT THE BOTTOM OF THIS PAGE --> This template normalises an input to be a yes/no output. == Usage == The template has five possible outputs depending on the default parameter (input if you will). In its simplest usage, these will all be either "yes" or "" (blank = nothing no characters). * {{Tlx|Yesno|yes}} → "yes" (also applies to "Yes", "YeS", etc, "Y", "y" and "1") * {{Tlx|Yesno|no}}..."
wikitext
text/x-wiki
<!-- {{Documentation subpage}} -->
<!-- PLEASE ADD CATEGORIES AND INTERWIKIS AT THE BOTTOM OF THIS PAGE -->
This template normalises an input to be a yes/no output.
== Usage ==
The template has five possible outputs depending on the default parameter (input if you will).
In its simplest usage, these will all be either "yes" or "" (blank = nothing no characters).
* {{Tlx|Yesno|yes}} → "yes" (also applies to "Yes", "YeS", etc, "Y", "y" and "1")
* {{Tlx|Yesno|no}} → "" (also applies to "No", "NO", "nO", "N", "n" and "0")
* {{Tlx|Yesno}} → ""
* {{Tlx|Yesno|¬}} → ""
* {{Tlx|Yesno|purplemonkeydishwasher}} → "yes" (also applies to any other value not given above)
Each of these can be over-ridden.
* {{Tlx|Yesno|yes|yes{{=}}bacon}} → "{{Yesno|yes|yes=bacon}}" (also applies to "Yes", "YeS", etc, "Y", "y" and "1")
* {{Tlx|Yesno|no|no{{=}}ham}} → "{{Yesno|no|no=ham}}" (also applies to "No", "NO", "nO", "N", "n" and "0")
* {{Tlx|Yesno||blank{{=}}eggs}} → "{{Yesno||blank=eggs}}"
** but {{Tlx|Yesno||no{{=}}ham}} → "{{Yesno||no=ham}}"
** and {{Tlx|Yesno||blank{{=}}eggs|no{{=}}ham}} → "{{Yesno||blank=eggs|no=ham}}"
* {{Tlx|Yesno|¬|¬{{=}}sausage|blank{{=}}eggs|no{{=}}ham}} → "{{Yesno|¬|¬=sausage|blank=eggs|no=ham}}"
** and {{Tlx|Yesno|¬{{=}}sausage|blank{{=}}eggs|no{{=}}ham}} → "{{Yesno|¬=sausage|blank=eggs|no=ham}}"
* {{Tlx|Yesno|purplemonkeydishwasher|def{{=}}cup-of-tea}} → "{{Tlx|Yesno|purplemonkeydishwasher|def{{=}}cup-of-tea}}" (also applies to any other value not given above)
** but {{Tlx|Yesno|purplemonkeydishwasher|yes{{=}}bacon}} → "{{Yesno|purplemonkeydishwasher|yes=bacon}}"
** and {{Tlx|Yesno|purplemonkeydishwasher|def{{=}}cup-of-tea|yes{{=}}bacon}} → "{{Yesno|purplemonkeydishwasher|def=cup-of-tea|yes=bacon}}"
This may be used (apparently perversely) thus:
* {{Tlx|Yesno|yes|yes{{=}}no|no{{=}}yes}} → "{{Yesno|yes|yes=no|no=yes}}"
* {{Tlx|Yesno|no|yes{{=}}no|no{{=}}yes}} → "{{Yesno|no|yes=no|no=yes}}"
This creates a logical inversion.
== TemplateData ==
<!-- {{TemplateData header}} -->
<templatedata>
{
"description": {
"en": "This template normalises an input to be a yes or nil output."
},
"format": "inline",
"params": {
"1": {
"label": {
"en": "Input value"
},
"description": {
"en": "The value to be evaluated."
},
"type": "string",
"required": true
},
"yes": {
"label": {
"en": "Output on yes"
},
"description": {
"en": "Specifies the output of the template when the input value is a case-insensitive forms of 'Yes', 'Y', 'True' or '1'."
},
"type": "string",
"required": false
},
"no": {
"label": {
"en": "Output on no"
},
"description": {
"en": "Specifies the output of the template when the input value is a case-insensitive forms of 'No', 'N', 'False', or '0'."
},
"type": "string",
"required": false
},
"blank": {
"label": {
"en": "Output on blank input"
},
"description": {
"en": "Specifies the output of the template when the input value is defined but is either empty or contains nothing but whitespace character(s)."
},
"type": "string",
"required": false
},
"¬": {
"label": {
"en": "Output on ¬"
},
"description": {
"en": "Specifies the output of the template when the input value is either '¬' or entirely missing (undefined)."
},
"type": "string",
"required": false
},
"def": {
"label": {
"en": "Definite output"
},
"description": {
"en": "Specifies the output of the template when the input value is defined but not a form of 'yes', 'no', '1', '0', '¬' or blank."
},
"type": "string",
"required": false
}
}
}
</templatedata>
== See also ==
* [[Module:Yesno]]
<includeonly>{{Sandbox other||
<!-- CATEGORIES AND INTERWIKIS HERE, THANKS -->
[[Category:Utility templates]]
}}</includeonly>
5715454d5a5aa65485043e4addc761a7d31454a5
Category:Utility templates
14
308
402
2025-08-21T15:24:23Z
Sharparam
284703
Created page with "Utility templates for editing."
wikitext
text/x-wiki
Utility templates for editing.
1efcbd3d8e1b3f909b9b968892e50b13cda3f04e
Module:Yesno
828
309
403
2025-08-21T15:25:12Z
Sharparam
284703
Created page with "-- Function allowing for consistent treatment of boolean-like wikitext input. -- It works similarly to the template {{yesno}}. return function (val, default) -- If your wiki uses non-ascii characters for any of "yes", "no", etc., you -- should replace "val:lower()" with "mw.ustring.lower(val)" in the -- following line. val = type(val) == 'string' and val:lower() or val if val == nil then return nil elseif val == true or val == 'yes' or val == 'y' or val =..."
Scribunto
text/plain
-- Function allowing for consistent treatment of boolean-like wikitext input.
-- It works similarly to the template {{yesno}}.
return function (val, default)
-- If your wiki uses non-ascii characters for any of "yes", "no", etc., you
-- should replace "val:lower()" with "mw.ustring.lower(val)" in the
-- following line.
val = type(val) == 'string' and val:lower() or val
if val == nil then
return nil
elseif val == true
or val == 'yes'
or val == 'y'
or val == 'true'
or val == 't'
or val == 'on'
or tonumber(val) == 1
then
return true
elseif val == false
or val == 'no'
or val == 'n'
or val == 'false'
or val == 'f'
or val == 'off'
or tonumber(val) == 0
then
return false
else
return default
end
end
f767643e7d12126d020d88d662a3dd057817b9dc
Module:Yesno/doc
828
310
404
2025-08-21T15:36:10Z
Sharparam
284703
Created page with "<noinclude><!-- --><!--{{#ifeq:{{SUBPAGENAME}}|doc||{{Documentation subpage}}}}--><!-- --></noinclude> <!-- Add categories where indicated at the bottom of this page and interwikis at Wikidata --> This module provides a consistent interface for processing boolean or boolean-style string input. While Lua allows the <code>true</code> and <code>false</code> boolean values, wikicode templates can only express boolean values through strings such as "1", "0", "yes", "no", etc...."
wikitext
text/x-wiki
<noinclude><!--
--><!--{{#ifeq:{{SUBPAGENAME}}|doc||{{Documentation subpage}}}}--><!--
--></noinclude>
<!-- Add categories where indicated at the bottom of this page and interwikis at Wikidata -->
This module provides a consistent interface for processing boolean or boolean-style string input.
While Lua allows the <code>true</code> and <code>false</code> boolean values, wikicode templates can only express boolean values through strings such as "1", "0", "yes", "no", etc.
This module processes these kinds of strings and turns them into boolean input for Lua to process.
It also returns <code>nil</code> values as <code>nil</code>, to allow for distinctions between <code>nil</code> and <code>false</code>.
The module also accepts other Lua structures as input, i.e. booleans, numbers, tables, and functions.
If it is passed input that it does not recognise as boolean or <code>nil</code>, it is possible to specify a default value to return.
== Syntax ==
<syntaxhighlight lang="lua">
yesno(value, default)
</syntaxhighlight>
<code>value</code> is the value to be tested.
Boolean input or boolean-style input (see below) always evaluates to either <code>true</code> or <code>false</code>, and <code>nil</code> always evaluates to <code>nil</code>.
Other values evaluate to <code>default</code>.
== Usage ==
First, load the module. Note that it can only be loaded from other Lua modules, not from normal wiki pages.
For normal wiki pages you can use {{tlx|yesno}} instead.
<syntaxhighlight lang="lua">
local yesno = require('Module:Yesno')
</syntaxhighlight>
Some input values always return <code>true</code>, and some always return <code>false</code>.
<code>nil</code> values always return <code>nil</code>.
<syntaxhighlight lang="lua">
-- These always return true:
yesno('yes')
yesno('y')
yesno('true')
yesno('t')
yesno('1')
yesno(1)
yesno(true)
-- These always return false:
yesno('no')
yesno('n')
yesno('false')
yesno('f')
yesno('0')
yesno(0)
yesno(false)
-- A nil value always returns nil:
yesno(nil)
</syntaxhighlight>
String values are converted to lower case before they are matched:
<syntaxhighlight lang="lua">
-- These always return true:
yesno('Yes')
yesno('YES')
yesno('yEs')
yesno('Y')
yesno('tRuE')
-- These always return false:
yesno('No')
yesno('NO')
yesno('nO')
yesno('N')
yesno('fALsE')
</syntaxhighlight>
You can specify a default value if <code>yesno</code> receives input other than that listed above.
If you don't supply a default, the module will return <code>nil</code> for these inputs.
<syntaxhighlight lang="lua">
-- These return nil:
yesno('foo')
yesno({})
yesno(5)
yesno(function() return 'This is a function.' end)
-- These return true:
yesno('foo', true)
yesno({}, true)
yesno(5, true)
yesno(function() return 'This is a function.' end, true)
-- These return "bar":
yesno('foo', 'bar')
yesno({}, 'bar')
yesno(5, 'bar')
yesno(function() return 'This is a function.' end, 'bar')
</syntaxhighlight>
Note that the blank string also functions this way:
<syntaxhighlight lang="lua">
yesno('') -- Returns nil.
yesno('', true) -- Returns true.
yesno('', 'bar') -- Returns "bar".
</syntaxhighlight>
Although the blank string usually evaluates to <code>false</code> in wikitext, it evaluates to <code>true</code> in Lua.
This module prefers the Lua behaviour over the wikitext behaviour.
If treating the blank string as <code>false</code> is important for your module, you will need to remove blank arguments at an earlier stage of processing.
<includeonly>{{Sandbox other||
<!-- Categories below this line; interwikis at Wikidata -->
[[Category:Modules]]
}}</includeonly><noinclude>
[[Category:Module documentation pages]]
</noinclude>
f0ef7ef64ea0756ea01bcaa9847ceca9782026b5
Template:About
10
311
405
2025-08-21T15:41:21Z
Sharparam
284703
Redirected page to [[Template:Disambiguation]]
wikitext
text/x-wiki
#REDIRECT [[Template:Disambiguation]]
42512ae1befdd6da09e528969fc1aff8da1c9a01
448
405
2025-08-21T16:25:56Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
wikitext
text/x-wiki
#REDIRECT [[Template:Disambiguation]]
42512ae1befdd6da09e528969fc1aff8da1c9a01
449
448
2025-08-21T16:27:25Z
Sharparam
284703
Use WP About template source
wikitext
text/x-wiki
{{#invoke:about|about}}<noinclude>
{{Documentation}}
</noinclude>
34b07e47d9b8220bf56dd9882945ad464b21a731
Module:Arguments
828
312
406
2025-08-21T15:46:08Z
Sharparam
284703
Created page with "-- This module provides easy processing of arguments passed to Scribunto from -- #invoke. It is intended for use by other Lua modules, and should not be -- called from #invoke directly. local libraryUtil = require('libraryUtil') local checkType = libraryUtil.checkType local arguments = {} -- Generate four different tidyVal functions, so that we don't have to check the -- options every time we call it. local function tidyValDefault(key, val) if type(val) == 'string'..."
Scribunto
text/plain
-- This module provides easy processing of arguments passed to Scribunto from
-- #invoke. It is intended for use by other Lua modules, and should not be
-- called from #invoke directly.
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local arguments = {}
-- Generate four different tidyVal functions, so that we don't have to check the
-- options every time we call it.
local function tidyValDefault(key, val)
if type(val) == 'string' then
val = val:match('^%s*(.-)%s*$')
if val == '' then
return nil
else
return val
end
else
return val
end
end
local function tidyValTrimOnly(key, val)
if type(val) == 'string' then
return val:match('^%s*(.-)%s*$')
else
return val
end
end
local function tidyValRemoveBlanksOnly(key, val)
if type(val) == 'string' then
if val:find('%S') then
return val
else
return nil
end
else
return val
end
end
local function tidyValNoChange(key, val)
return val
end
local function matchesTitle(given, title)
local tp = type( given )
return (tp == 'string' or tp == 'number') and mw.title.new( given ).prefixedText == title
end
local translate_mt = { __index = function(t, k) return k end }
function arguments.getArgs(frame, options)
checkType('getArgs', 1, frame, 'table', true)
checkType('getArgs', 2, options, 'table', true)
frame = frame or {}
options = options or {}
--[[
-- Set up argument translation.
--]]
options.translate = options.translate or {}
if getmetatable(options.translate) == nil then
setmetatable(options.translate, translate_mt)
end
if options.backtranslate == nil then
options.backtranslate = {}
for k,v in pairs(options.translate) do
options.backtranslate[v] = k
end
end
if options.backtranslate and getmetatable(options.backtranslate) == nil then
setmetatable(options.backtranslate, {
__index = function(t, k)
if options.translate[k] ~= k then
return nil
else
return k
end
end
})
end
--[[
-- Get the argument tables. If we were passed a valid frame object, get the
-- frame arguments (fargs) and the parent frame arguments (pargs), depending
-- on the options set and on the parent frame's availability. If we weren't
-- passed a valid frame object, we are being called from another Lua module
-- or from the debug console, so assume that we were passed a table of args
-- directly, and assign it to a new variable (luaArgs).
--]]
local fargs, pargs, luaArgs
if type(frame.args) == 'table' and type(frame.getParent) == 'function' then
if options.wrappers then
--[[
-- The wrappers option makes Module:Arguments look up arguments in
-- either the frame argument table or the parent argument table, but
-- not both. This means that users can use either the #invoke syntax
-- or a wrapper template without the loss of performance associated
-- with looking arguments up in both the frame and the parent frame.
-- Module:Arguments will look up arguments in the parent frame
-- if it finds the parent frame's title in options.wrapper;
-- otherwise it will look up arguments in the frame object passed
-- to getArgs.
--]]
local parent = frame:getParent()
if not parent then
fargs = frame.args
else
local title = parent:getTitle():gsub('/sandbox$', '')
local found = false
if matchesTitle(options.wrappers, title) then
found = true
elseif type(options.wrappers) == 'table' then
for _,v in pairs(options.wrappers) do
if matchesTitle(v, title) then
found = true
break
end
end
end
-- We test for false specifically here so that nil (the default) acts like true.
if found or options.frameOnly == false then
pargs = parent.args
end
if not found or options.parentOnly == false then
fargs = frame.args
end
end
else
-- options.wrapper isn't set, so check the other options.
if not options.parentOnly then
fargs = frame.args
end
if not options.frameOnly then
local parent = frame:getParent()
pargs = parent and parent.args or nil
end
end
if options.parentFirst then
fargs, pargs = pargs, fargs
end
else
luaArgs = frame
end
-- Set the order of precedence of the argument tables. If the variables are
-- nil, nothing will be added to the table, which is how we avoid clashes
-- between the frame/parent args and the Lua args.
local argTables = {fargs}
argTables[#argTables + 1] = pargs
argTables[#argTables + 1] = luaArgs
--[[
-- Generate the tidyVal function. If it has been specified by the user, we
-- use that; if not, we choose one of four functions depending on the
-- options chosen. This is so that we don't have to call the options table
-- every time the function is called.
--]]
local tidyVal = options.valueFunc
if tidyVal then
if type(tidyVal) ~= 'function' then
error(
"bad value assigned to option 'valueFunc'"
.. '(function expected, got '
.. type(tidyVal)
.. ')',
2
)
end
elseif options.trim ~= false then
if options.removeBlanks ~= false then
tidyVal = tidyValDefault
else
tidyVal = tidyValTrimOnly
end
else
if options.removeBlanks ~= false then
tidyVal = tidyValRemoveBlanksOnly
else
tidyVal = tidyValNoChange
end
end
--[[
-- Set up the args, metaArgs and nilArgs tables. args will be the one
-- accessed from functions, and metaArgs will hold the actual arguments. Nil
-- arguments are memoized in nilArgs, and the metatable connects all of them
-- together.
--]]
local args, metaArgs, nilArgs, metatable = {}, {}, {}, {}
setmetatable(args, metatable)
local function mergeArgs(tables)
--[[
-- Accepts multiple tables as input and merges their keys and values
-- into one table. If a value is already present it is not overwritten;
-- tables listed earlier have precedence. We are also memoizing nil
-- values, which can be overwritten if they are 's' (soft).
--]]
for _, t in ipairs(tables) do
for key, val in pairs(t) do
if metaArgs[key] == nil and nilArgs[key] ~= 'h' then
local tidiedVal = tidyVal(key, val)
if tidiedVal == nil then
nilArgs[key] = 's'
else
metaArgs[key] = tidiedVal
end
end
end
end
end
--[[
-- Define metatable behaviour. Arguments are memoized in the metaArgs table,
-- and are only fetched from the argument tables once. Fetching arguments
-- from the argument tables is the most resource-intensive step in this
-- module, so we try and avoid it where possible. For this reason, nil
-- arguments are also memoized, in the nilArgs table. Also, we keep a record
-- in the metatable of when pairs and ipairs have been called, so we do not
-- run pairs and ipairs on the argument tables more than once. We also do
-- not run ipairs on fargs and pargs if pairs has already been run, as all
-- the arguments will already have been copied over.
--]]
metatable.__index = function (t, key)
--[[
-- Fetches an argument when the args table is indexed. First we check
-- to see if the value is memoized, and if not we try and fetch it from
-- the argument tables. When we check memoization, we need to check
-- metaArgs before nilArgs, as both can be non-nil at the same time.
-- If the argument is not present in metaArgs, we also check whether
-- pairs has been run yet. If pairs has already been run, we return nil.
-- This is because all the arguments will have already been copied into
-- metaArgs by the mergeArgs function, meaning that any other arguments
-- must be nil.
--]]
if type(key) == 'string' then
key = options.translate[key]
end
local val = metaArgs[key]
if val ~= nil then
return val
elseif metatable.donePairs or nilArgs[key] then
return nil
end
for _, argTable in ipairs(argTables) do
local argTableVal = tidyVal(key, argTable[key])
if argTableVal ~= nil then
metaArgs[key] = argTableVal
return argTableVal
end
end
nilArgs[key] = 'h'
return nil
end
metatable.__newindex = function (t, key, val)
-- This function is called when a module tries to add a new value to the
-- args table, or tries to change an existing value.
if type(key) == 'string' then
key = options.translate[key]
end
if options.readOnly then
error(
'could not write to argument table key "'
.. tostring(key)
.. '"; the table is read-only',
2
)
elseif options.noOverwrite and args[key] ~= nil then
error(
'could not write to argument table key "'
.. tostring(key)
.. '"; overwriting existing arguments is not permitted',
2
)
elseif val == nil then
--[[
-- If the argument is to be overwritten with nil, we need to erase
-- the value in metaArgs, so that __index, __pairs and __ipairs do
-- not use a previous existing value, if present; and we also need
-- to memoize the nil in nilArgs, so that the value isn't looked
-- up in the argument tables if it is accessed again.
--]]
metaArgs[key] = nil
nilArgs[key] = 'h'
else
metaArgs[key] = val
end
end
local function translatenext(invariant)
local k, v = next(invariant.t, invariant.k)
invariant.k = k
if k == nil then
return nil
elseif type(k) ~= 'string' or not options.backtranslate then
return k, v
else
local backtranslate = options.backtranslate[k]
if backtranslate == nil then
-- Skip this one. This is a tail call, so this won't cause stack overflow
return translatenext(invariant)
else
return backtranslate, v
end
end
end
metatable.__pairs = function ()
-- Called when pairs is run on the args table.
if not metatable.donePairs then
mergeArgs(argTables)
metatable.donePairs = true
end
return translatenext, { t = metaArgs }
end
local function inext(t, i)
-- This uses our __index metamethod
local v = t[i + 1]
if v ~= nil then
return i + 1, v
end
end
metatable.__ipairs = function (t)
-- Called when ipairs is run on the args table.
return inext, t, 0
end
return args
end
return arguments
3134ecce8429b810d445e29eae115e2ae4c36c53
Module:Arguments/doc
828
313
407
2025-08-21T15:48:06Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Module:Arguments|Module and documentation on Wikipedia]] <includeonly>{{Sandbox other|| <!-- Categories below this line; interwikis at Wikidata --> [[Category:Utility modules]] }}</includeonly> <noinclude> [[Category:Module documentation pages]] </noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Module:Arguments|Module and documentation on Wikipedia]]
<includeonly>{{Sandbox other||
<!-- Categories below this line; interwikis at Wikidata -->
[[Category:Utility modules]]
}}</includeonly>
<noinclude>
[[Category:Module documentation pages]]
</noinclude>
28b94b568a78688d3d0ac27f55e89b64d30cbc2c
Module:Redirect
828
314
408
2025-08-21T15:52:26Z
Sharparam
284703
Created page with "-- This module provides functions for getting the target of a redirect page. local p = {} -- Gets a mw.title object, using pcall to avoid generating script errors if we -- are over the expensive function count limit (among other possible causes). local function getTitle(...) local success, titleObj = pcall(mw.title.new, ...) if success then return titleObj else return nil end end -- Gets the name of a page that a redirect leads to, or nil if it isn't a -- redi..."
Scribunto
text/plain
-- This module provides functions for getting the target of a redirect page.
local p = {}
-- Gets a mw.title object, using pcall to avoid generating script errors if we
-- are over the expensive function count limit (among other possible causes).
local function getTitle(...)
local success, titleObj = pcall(mw.title.new, ...)
if success then
return titleObj
else
return nil
end
end
-- Gets the name of a page that a redirect leads to, or nil if it isn't a
-- redirect.
function p.getTargetFromText(text)
local target = string.match(
text,
"^%s*#[Rr][Ee][Dd][Ii][Rr][Ee][Cc][Tt]%s*:?%s*%[%[([^%[%]|]-)%]%]"
) or string.match(
text,
"^%s*#[Rr][Ee][Dd][Ii][Rr][Ee][Cc][Tt]%s*:?%s*%[%[([^%[%]|]-)|[^%[%]]-%]%]"
)
return target and mw.uri.decode(target, 'PATH')
end
-- Gets the target of a redirect. If the page specified is not a redirect,
-- returns nil.
function p.getTarget(page, fulltext)
-- Get the title object. Both page names and title objects are allowed
-- as input.
local titleObj
if type(page) == 'string' or type(page) == 'number' then
titleObj = getTitle(page)
elseif type(page) == 'table' and type(page.getContent) == 'function' then
titleObj = page
else
error(string.format(
"bad argument #1 to 'getTarget'"
.. " (string, number, or title object expected, got %s)",
type(page)
), 2)
end
if not titleObj then
return nil
end
local targetTitle = titleObj.redirectTarget
if targetTitle then
if fulltext then
return targetTitle.fullText
else
return targetTitle.prefixedText
end
else
return nil
end
end
--[[
-- Given a single page name determines what page it redirects to and returns the
-- target page name, or the passed page name when not a redirect. The passed
-- page name can be given as plain text or as a page link.
--
-- Returns page name as plain text, or when the bracket parameter is given, as a
-- page link. Returns an error message when page does not exist or the redirect
-- target cannot be determined for some reason.
--]]
function p.luaMain(rname, bracket, fulltext)
if type(rname) ~= "string" or not rname:find("%S") then
return nil
end
bracket = bracket and "[[%s]]" or "%s"
rname = rname:match("%[%[(.+)%]%]") or rname
local target = p.getTarget(rname, fulltext)
local ret = target or rname
ret = getTitle(ret)
if ret then
if fulltext then
ret = ret.fullText
else
ret = ret.prefixedText
end
return bracket:format(ret)
else
return nil
end
end
-- Provides access to the luaMain function from wikitext.
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame, {frameOnly = true})
return p.luaMain(args[1], args.bracket, args.fulltext) or ''
end
-- Returns true if the specified page is a redirect, and false otherwise.
function p.luaIsRedirect(page)
local titleObj = getTitle(page)
if not titleObj then
return false
end
if titleObj.isRedirect then
return true
else
return false
end
end
-- Provides access to the luaIsRedirect function from wikitext, returning 'yes'
-- if the specified page is a redirect, and the blank string otherwise.
function p.isRedirect(frame)
local args = require('Module:Arguments').getArgs(frame, {frameOnly = true})
if p.luaIsRedirect(args[1]) then
return 'yes'
else
return ''
end
end
return p
a224c45940343d66f49a78b0a39b2045e2c45d20
Category:Utility modules
14
315
409
2025-08-21T15:55:00Z
Sharparam
284703
Created page with "Utility Lua modules."
wikitext
text/x-wiki
Utility Lua modules.
0aa79c3b49606d401d8b0a12fa6c596e821621d8
Category:Module documentation pages
14
316
410
2025-08-21T15:55:36Z
Sharparam
284703
Created page with "Pages that document usage for Lua modules."
wikitext
text/x-wiki
Pages that document usage for Lua modules.
85aa5bf005bae53b26da6d5726824c4daf1e9ab5
Module:Redirect/doc
828
317
411
2025-08-21T15:56:47Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Module:Redirect|Module and documentation on Wikipedia]] <includeonly>{{Sandbox other|| [[Category:Utility modules]] }}</includeonly> <noinclude> [[Category:Module documentation pages]] </noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Module:Redirect|Module and documentation on Wikipedia]]
<includeonly>{{Sandbox other||
[[Category:Utility modules]]
}}</includeonly>
<noinclude>
[[Category:Module documentation pages]]
</noinclude>
436eeeb7a653286c92f328a118549b21f6c450a5
Module:Wikitext Parsing
828
318
412
2025-08-21T16:00:52Z
Sharparam
284703
Created page with "require("strict") --Helper functions local function startswith(text, subtext) return string.sub(text, 1, #subtext) == subtext end local function endswith(text, subtext) return string.sub(text, -#subtext, -1) == subtext end local function allcases(s) return s:gsub("%a", function(c) return "["..c:upper()..c:lower().."]" end) end local trimcache = {} local whitespace = {[" "]=1, ["\n"]=1, ["\t"]=1, ["\r"]=1} local function cheaptrim(str) --mw.text.trim is surprising..."
Scribunto
text/plain
require("strict")
--Helper functions
local function startswith(text, subtext)
return string.sub(text, 1, #subtext) == subtext
end
local function endswith(text, subtext)
return string.sub(text, -#subtext, -1) == subtext
end
local function allcases(s)
return s:gsub("%a", function(c)
return "["..c:upper()..c:lower().."]"
end)
end
local trimcache = {}
local whitespace = {[" "]=1, ["\n"]=1, ["\t"]=1, ["\r"]=1}
local function cheaptrim(str) --mw.text.trim is surprisingly expensive, so here's an alternative approach
local quick = trimcache[str]
if quick then
return quick
else
-- local out = string.gsub(str, "^%s*(.-)%s*$", "%1")
local lowEnd
local strlen = #str
for i = 1,strlen do
if not whitespace[string.sub(str, i, i)] then
lowEnd = i
break
end
end
if not lowEnd then
trimcache[str] = ""
return ""
end
for i = strlen,1,-1 do
if not whitespace[string.sub(str, i, i)] then
local out = string.sub(str, lowEnd, i)
trimcache[str] = out
return out
end
end
end
end
--[=[ Implementation notes
---- NORMAL HTML TAGS ----
Tags are very strict on how they want to start, but loose on how they end.
The start must strictly follow <[tAgNaMe](%s|>) with no room for whitespace in
the tag's name, but may then flow as they want afterwards, making
<div\nclass\n=\n"\nerror\n"\n> valid
There's no sense of escaping < or >
E.g.
<div class="error\>"> will end at \> despite it being inside a quote
<div class="<span class="error">error</span>"> will not process the larger div
If a tag has no end, it will consume all text instead of not processing
---- NOPROCESSING TAGS (nowiki, pre, syntaxhighlight, source, etc.) ----
(In most comments, <source> will not be mentioned. This is because it is the
deprecated version of <syntaxhighlight>)
No-Processing tags have some interesting differences to the above rules.
For example, their syntax is a lot stricter. While an opening tag appears to
follow the same set of rules, A closing tag can't have any sort of extra
formatting period. While </div a/a> is valid, </nowiki a/a> isn't - only
newlines and spaces/tabs are allowed in closing tags.
Note that, even though <pre> tags cause a visual change when the ending tag has
extra formatting, it won't cause the no-processing effects. For some reason, the
format must be strict for that to apply.
Both the content inside the tag pair and the content inside each side of the
pair is not processed. E.g. <nowiki |}}>|}}</nowiki> would have both of the |}}
escaped in practice.
When something in the code is referenced to as a "Nowiki Tag", it means a tag
which causes wiki text to not be processed, which includes <nowiki>, <pre>,
and <syntaxhighlight>
Since we only care about these tags, we can ignore the idea of an intercepting
tag preventing processing, and just go straight for the first ending we can find
If there is no ending to find, the tag will NOT consume the rest of the text in
terms of processing behaviour (though <pre> will appear to have an effect).
Even if there is no end of the tag, the content inside the opening half will
still be unprocessed, meaning {{X20|<nowiki }}>}} wouldn't end at the first }}
despite there being no ending to the tag.
Note that there are some tags, like <math>, which also function like <nowiki>
which are included in this aswell. Some other tags, like <ref>, have far too
unpredictable behaviour to be handled currently (they'd have to be split and
processed as something seperate - its complicated, but maybe not impossible.)
I suspect that every tag listed in [[Special:Version]] may behave somewhat like
this, but that's far too many cases worth checking for rarely used tags that may
not even have a good reason to contain {{ or }} anyways, so we leave them alone.
---- HTML COMMENTS AND INCLUDEONLY ----
HTML Comments are about as basic as it could get for this
Start at <!--, end at -->, no extra conditions. Simple enough
If a comment has no end, it will eat all text instead of not being processed
includeonly tags function mostly like a regular nowiki tag, with the exception
that the tag will actually consume all future text if not given an ending as
opposed to simply giving up and not changing anything. Due to complications and
the fact that this is far less likely to be present on a page, aswell as being
something that may not want to be escaped, includeonly tags are ignored during
our processing
--]=]
local validtags = {nowiki=1, pre=1, syntaxhighlight=1, source=1, math=1}
--This function expects the string to start with the tag
local function TestForNowikiTag(text, scanPosition)
local tagName = (string.match(text, "^<([^\n />]+)", scanPosition) or ""):lower()
if not validtags[tagName] then
return nil
end
local nextOpener = string.find(text, "<", scanPosition+1) or -1
local nextCloser = string.find(text, ">", scanPosition+1) or -1
if nextCloser > -1 and (nextOpener == -1 or nextCloser < nextOpener) then
local startingTag = string.sub(text, scanPosition, nextCloser)
--We have our starting tag (E.g. '<pre style="color:red">')
--Now find our ending...
if endswith(startingTag, "/>") then --self-closing tag (we are our own ending)
return {
Tag = tagName,
Start = startingTag,
Content = "", End = "",
Length = #startingTag
}
else
local endingTagStart, endingTagEnd = string.find(text, "</"..allcases(tagName).."[ \t\n]*>", scanPosition)
if endingTagStart then --Regular tag formation
local endingTag = string.sub(text, endingTagStart, endingTagEnd)
local tagContent = string.sub(text, nextCloser+1, endingTagStart-1)
return {
Tag = tagName,
Start = startingTag,
Content = tagContent,
End = endingTag,
Length = #startingTag + #tagContent + #endingTag
}
else --Content inside still needs escaping (also linter error!)
return {
Tag = tagName,
Start = startingTag,
Content = "", End = "",
Length = #startingTag
}
end
end
end
return nil
end
local function TestForComment(text, scanPosition) --Like TestForNowikiTag but for <!-- -->
if string.match(text, "^<!%-%-", scanPosition) then
local commentEnd = string.find(text, "-->", scanPosition+4, true)
if commentEnd then
return {
Start = "<!--", End = "-->",
Content = string.sub(text, scanPosition+4, commentEnd-1),
Length = commentEnd-scanPosition+3
}
else --Consumes all text if not given an ending
return {
Start = "<!--", End = "",
Content = string.sub(text, scanPosition+4),
Length = #text-scanPosition+1
}
end
end
return nil
end
--[[ Implementation notes
The goal of this function is to escape all text that wouldn't be parsed if it
was preprocessed (see above implementation notes).
Using keepComments will keep all HTML comments instead of removing them. They
will still be escaped regardless to avoid processing errors
--]]
local function PrepareText(text, keepComments)
local newtext = {}
local scanPosition = 1
while true do
local NextCheck = string.find(text, "<[NnSsPpMm!]", scanPosition) --Advance to the next potential tag we care about
if not NextCheck then --Done
newtext[#newtext+1] = string.sub(text,scanPosition)
break
end
newtext[#newtext+1] = string.sub(text,scanPosition,NextCheck-1)
scanPosition = NextCheck
local Comment = TestForComment(text, scanPosition)
if Comment then
if keepComments then
newtext[#newtext+1] = Comment.Start .. mw.text.nowiki(Comment.Content) .. Comment.End
end
scanPosition = scanPosition + Comment.Length
else
local Tag = TestForNowikiTag(text, scanPosition)
if Tag then
local newTagStart = "<" .. mw.text.nowiki(string.sub(Tag.Start,2,-2)) .. ">"
local newTagEnd =
Tag.End == "" and "" or --Respect no tag ending
"</" .. mw.text.nowiki(string.sub(Tag.End,3,-2)) .. ">"
local newContent = mw.text.nowiki(Tag.Content)
newtext[#newtext+1] = newTagStart .. newContent .. newTagEnd
scanPosition = scanPosition + Tag.Length
else --Nothing special, move on...
newtext[#newtext+1] = string.sub(text, scanPosition, scanPosition)
scanPosition = scanPosition + 1
end
end
end
return table.concat(newtext, "")
end
--[=[ Implementation notes
This function is an alternative to Transcluder's getParameters which considers
the potential for a singular { or } or other odd syntax that %b doesn't like to
be in a parameter's value.
When handling the difference between {{ and {{{, mediawiki will attempt to match
as many sequences of {{{ as possible before matching a {{
E.g.
{{{{A}}}} -> { {{{A}}} }
{{{{{{{{Text|A}}}}}}}} -> {{ {{{ {{{Text|A}}} }}} }}
If there aren't enough triple braces on both sides, the parser will compromise
for a template interpretation.
E.g.
{{{{A}} }} -> {{ {{ A }} }}
While there are technically concerns about things such as wikilinks breaking
template processing (E.g. {{[[}}]]}} doesn't stop at the first }}), it shouldn't
be our job to process inputs perfectly when the input has garbage ({ / } isn't
legal in titles anyways, so if something's unmatched in a wikilink, it's
guaranteed GIGO)
Setting dontEscape will prevent running the input text through EET. Avoid
setting this to true if you don't have to set it.
Returned values:
A table of all templates. Template data goes as follows:
Text: The raw text of the template
Name: The name of the template
Args: A list of arguments
Children: A list of immediate template children
--]=]
--Helper functions
local function boundlen(pair)
return pair.End-pair.Start+1
end
--Main function
local function ParseTemplates(InputText, dontEscape)
--Setup
if not dontEscape then
InputText = PrepareText(InputText)
end
local function finalise(text)
if not dontEscape then
return mw.text.decode(text)
else
return text
end
end
local function CreateContainerObj(Container)
Container.Text = {}
Container.Args = {}
Container.ArgOrder = {}
Container.Children = {}
-- Container.Name = nil
-- Container.Value = nil
-- Container.Key = nil
Container.BeyondStart = false
Container.LastIndex = 1
Container.finalise = finalise
function Container:HandleArgInput(character, internalcall)
if not internalcall then
self.Text[#self.Text+1] = character
end
if character == "=" then
if self.Key then
self.Value[#self.Value+1] = character
else
self.Key = cheaptrim(self.Value and table.concat(self.Value, "") or "")
self.Value = {}
end
else --"|" or "}"
if not self.Name then
self.Name = cheaptrim(self.Value and table.concat(self.Value, "") or "")
self.Value = nil
else
self.Value = self.finalise(self.Value and table.concat(self.Value, "") or "")
if self.Key then
self.Key = self.finalise(self.Key)
self.Args[self.Key] = cheaptrim(self.Value)
self.ArgOrder[#self.ArgOrder+1] = self.Key
else
local Key = tostring(self.LastIndex)
self.Args[Key] = self.Value
self.ArgOrder[#self.ArgOrder+1] = Key
self.LastIndex = self.LastIndex + 1
end
self.Key = nil
self.Value = nil
end
end
end
function Container:AppendText(text, ftext)
self.Text[#self.Text+1] = (ftext or text)
if not self.Value then
self.Value = {}
end
self.BeyondStart = self.BeyondStart or (#table.concat(self.Text, "") > 2)
if self.BeyondStart then
self.Value[#self.Value+1] = text
end
end
function Container:Clean(IsTemplate)
self.Text = table.concat(self.Text, "")
if self.Value and IsTemplate then
self.Value = {string.sub(table.concat(self.Value, ""), 1, -3)} --Trim ending }}
self:HandleArgInput("|", true) --Simulate ending
end
self.Value = nil
self.Key = nil
self.BeyondStart = nil
self.LastIndex = nil
self.finalise = nil
self.HandleArgInput = nil
self.AppendText = nil
self.Clean = nil
end
return Container
end
--Step 1: Find and escape the content of all wikilinks on the page, which are stronger than templates (see implementation notes)
local scannerPosition = 1
local wikilinks = {}
local openWikilinks = {}
while true do
local Position, _, Character = string.find(InputText, "([%[%]])%1", scannerPosition)
if not Position then --Done
break
end
scannerPosition = Position+2 --+2 to pass the [[ / ]]
if Character == "[" then --Add a [[ to the pending wikilink queue
openWikilinks[#openWikilinks+1] = Position
else --Pair up the ]] to any available [[
if #openWikilinks >= 1 then
local start = table.remove(openWikilinks) --Pop the latest [[
wikilinks[start] = {Start=start, End=Position+1, Type="Wikilink"} --Note the pair
end
end
end
--Step 2: Find the bounds of every valid template and variable ({{ and {{{)
local scannerPosition = 1
local templates = {}
local variables = {}
local openBrackets = {}
while true do
local Start, _, Character = string.find(InputText, "([{}])%1", scannerPosition)
if not Start then --Done (both 9e9)
break
end
local _, End = string.find(InputText, "^"..Character.."+", Start)
scannerPosition = Start --Get to the {{ / }} set
if Character == "{" then --Add the {{+ set to the queue
openBrackets[#openBrackets+1] = {Start=Start, End=End}
else --Pair up the }} to any available {{, accounting for {{{ / }}}
local BracketCount = End-Start+1
while BracketCount >= 2 and #openBrackets >= 1 do
local OpenSet = table.remove(openBrackets)
if boundlen(OpenSet) >= 3 and BracketCount >= 3 then --We have a {{{variable}}} (both sides have 3 spare)
variables[OpenSet.End-2] = {Start=OpenSet.End-2, End=scannerPosition+2, Type="Variable"} --Done like this to ensure chronological order
BracketCount = BracketCount - 3
OpenSet.End = OpenSet.End - 3
scannerPosition = scannerPosition + 3
else --We have a {{template}} (both sides have 2 spare, but at least one side doesn't have 3 spare)
templates[OpenSet.End-1] = {Start=OpenSet.End-1, End=scannerPosition+1, Type="Template"} --Done like this to ensure chronological order
BracketCount = BracketCount - 2
OpenSet.End = OpenSet.End - 2
scannerPosition = scannerPosition + 2
end
if boundlen(OpenSet) >= 2 then --Still has enough data left, leave it in
openBrackets[#openBrackets+1] = OpenSet
end
end
end
scannerPosition = End --Now move past the bracket set
end
--Step 3: Re-trace every object using their known bounds, collecting our parameters with (slight) ease
local scannerPosition = 1
local activeObjects = {}
local finalObjects = {}
while true do
local LatestObject = activeObjects[#activeObjects] --Commonly needed object
local NNC, _, Character --NNC = NextNotableCharacter
if LatestObject then
NNC, _, Character = string.find(InputText, "([{}%[%]|=])", scannerPosition)
else
NNC, _, Character = string.find(InputText, "([{}])", scannerPosition) --We are only after templates right now
end
if not NNC then
break
end
if NNC > scannerPosition and LatestObject then
local scannedContent = string.sub(InputText, scannerPosition, NNC-1)
LatestObject:AppendText(scannedContent, finalise(scannedContent))
end
scannerPosition = NNC+1
if Character == "{" or Character == "[" then
local Container = templates[NNC] or variables[NNC] or wikilinks[NNC]
if Container then
CreateContainerObj(Container)
if Container.Type == "Template" then
Container:AppendText("{{")
scannerPosition = NNC+2
elseif Container.Type == "Variable" then
Container:AppendText("{{{")
scannerPosition = NNC+3
else --Wikilink
Container:AppendText("[[")
scannerPosition = NNC+2
end
if LatestObject and Container.Type == "Template" then --Only templates count as children
LatestObject.Children[#LatestObject.Children+1] = Container
end
activeObjects[#activeObjects+1] = Container
elseif LatestObject then
LatestObject:AppendText(Character)
end
elseif Character == "}" or Character == "]" then
if LatestObject then
LatestObject:AppendText(Character)
if LatestObject.End == NNC then
if LatestObject.Type == "Template" then
LatestObject:Clean(true)
finalObjects[#finalObjects+1] = LatestObject
else
LatestObject:Clean(false)
end
activeObjects[#activeObjects] = nil
local NewLatest = activeObjects[#activeObjects]
if NewLatest then
NewLatest:AppendText(LatestObject.Text) --Append to new latest
end
end
end
else --| or =
if LatestObject then
LatestObject:HandleArgInput(Character)
end
end
end
--Step 4: Fix the order
local FixedOrder = {}
local SortableReference = {}
for _,Object in next,finalObjects do
SortableReference[#SortableReference+1] = Object.Start
end
table.sort(SortableReference)
for i = 1,#SortableReference do
local start = SortableReference[i]
for n,Object in next,finalObjects do
if Object.Start == start then
finalObjects[n] = nil
Object.Start = nil --Final cleanup
Object.End = nil
Object.Type = nil
FixedOrder[#FixedOrder+1] = Object
break
end
end
end
--Finished, return
return FixedOrder
end
local p = {}
--Main entry points
p.PrepareText = PrepareText
p.ParseTemplates = ParseTemplates
--Extra entry points, not really required
p.TestForNowikiTag = TestForNowikiTag
p.TestForComment = TestForComment
return p
--[==[ console tests
local s = [=[Hey!{{Text|<nowiki | ||>
Hey! }}
A</nowiki>|<!--AAAAA|AAA-->Should see|Shouldn't see}}]=]
local out = p.PrepareText(s)
mw.logObject(out)
local s = [=[B<!--
Hey!
-->A]=]
local out = p.TestForComment(s, 2)
mw.logObject(out); mw.log(string.sub(s, 2, out.Length))
local a = p.ParseTemplates([=[
{{User:Aidan9382/templates/dummy
|A|B|C {{{A|B}}} { } } {
|<nowiki>D</nowiki>
|<pre>E
|F</pre>
|G|=|a=|A = [[{{PAGENAME}}|A=B]]{{Text|1==<nowiki>}}</nowiki>}}|A B=Success}}
]=])
mw.logObject(a)
]==]
0e960df7b62b2131c8e704eb249b7ce1654ad5c3
Module:Wikitext Parsing/doc
828
319
413
2025-08-21T16:01:43Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Module:Wikitext Parsing|Module and documentation on Wikipedia]] <noinclude>[[Category:Module documentation pages]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Module:Wikitext Parsing|Module and documentation on Wikipedia]]
<noinclude>[[Category:Module documentation pages]]</noinclude>
ac42eaa08fed582c3bee9fe96d8926c3a348bd4c
Module:Disambiguation/templates
828
320
414
2025-08-21T16:06:25Z
Sharparam
284703
Created page with "-- This page contains a table of all disambiguation templates and their -- redirects. Templates names are capitalized, and the Template: prefix is -- removed. Templates are grouped with the main template first, followed by -- its redirects. return { -- ["Disambiguation"] = true, -- ["DAB"] = true, -- ["Dab"] = true, -- ["Dab page"] = true, -- ["Dabpage"] = true, -- ["Dbig"] = true, -- ["Dis"] = true, -- ["Disam"] = true, -- ["Disamb"] = true, -- ["Disambig"] =..."
Scribunto
text/plain
-- This page contains a table of all disambiguation templates and their
-- redirects. Templates names are capitalized, and the Template: prefix is
-- removed. Templates are grouped with the main template first, followed by
-- its redirects.
return {
-- ["Disambiguation"] = true,
-- ["DAB"] = true,
-- ["Dab"] = true,
-- ["Dab page"] = true,
-- ["Dabpage"] = true,
-- ["Dbig"] = true,
-- ["Dis"] = true,
-- ["Disam"] = true,
-- ["Disamb"] = true,
-- ["Disambig"] = true,
-- ["Disambig misspelling"] = true,
-- ["Disambiguation page"] = true,
-- ["Project disambiguation"] = true,
-- ["Shortcut disambig"] = true,
-- ["Disambiguation cleanup"] = true,
-- ["Cleanup disambig"] = true,
-- ["Cleanup disambiguation"] = true,
-- ["CleanupDisambig"] = true,
-- ["Dab cleanup"] = true,
-- ["Dab-cleanup"] = true,
-- ["Dabclean"] = true,
-- ["Disamb-cleanup"] = true,
-- ["Disambcleanup"] = true,
-- ["Disambig cleanup"] = true,
-- ["Disambig-cleanup"] = true,
-- ["Disambig-CU"] = true,
-- ["Disambig-cu"] = true,
-- ["Disambigcleanup"] = true,
-- ["Disambiguate-cleanup"] = true,
-- ["Disambiguation-cleanup"] = true,
-- ["Template disambiguation"] = true,
-- ["Template ambiguous"] = true,
-- ["Template dab"] = true,
-- ["Template disambig"] = true
}
a19e74ebb8bfa5dd246ddd3c8e8c7856e6846121
Module:Disambiguation/templates/doc
828
321
415
2025-08-21T16:07:04Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Module:Disambiguation/templates|Module and documentation on Wikipedia]] <noinclude>[[Category:Module documentation pages]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Module:Disambiguation/templates|Module and documentation on Wikipedia]]
<noinclude>[[Category:Module documentation pages]]</noinclude>
bb28f1f1a9660ec5d6848300320ed9d8d83cca8a
Module:Disambiguation
828
322
416
2025-08-21T16:07:30Z
Sharparam
284703
Created page with "local p = {} local mRedirect = require('Module:Redirect') local disambiguationTemplates = mw.loadData('Module:Disambiguation/templates') local PrepareText = require('Module:Wikitext Parsing').PrepareText local function capitalize(s) -- This function only works on ASCII strings. If your wiki has -- disambiguation templates that use Unicode strings, use the commented-out -- line instead. Enwiki uses ASCII string manipulation only here to improve -- performance. retur..."
Scribunto
text/plain
local p = {}
local mRedirect = require('Module:Redirect')
local disambiguationTemplates = mw.loadData('Module:Disambiguation/templates')
local PrepareText = require('Module:Wikitext Parsing').PrepareText
local function capitalize(s)
-- This function only works on ASCII strings. If your wiki has
-- disambiguation templates that use Unicode strings, use the commented-out
-- line instead. Enwiki uses ASCII string manipulation only here to improve
-- performance.
return s:sub(1, 1):upper() .. s:sub(2, -1)
-- return mw.ustring.upper(mw.ustring.sub(1, 1)) .. mw.ustring.sub(2, -1)
end
local function isDisambiguationTemplate(template)
return disambiguationTemplates[capitalize(template)] or false
end
p.isDisambiguation = function(content)
-- false if there is no content
if content == nil then
return false
end
-- redirects are not disambiguation pages
if mRedirect.getTargetFromText(content) ~= nil then
return false
end
-- check for disambiguation templates in the content
local templateNames = {}
-- remove nowiki content and html comments for this check
local activecontent = PrepareText(content)
for template in string.gmatch(activecontent, "{{%s*([^|}]-)%s*[|}]") do
if isDisambiguationTemplate(template) then
return true
end
end
-- check for magic word
if string.find(content, "__DISAMBIG__", 1, true) ~= nil then
return true
end
return false
end
p._isDisambiguationPage = function(page)
-- Look "(disambiguation)" in the title
if string.find(page, "(disambiguation)",0,true) ~= nil then
return true;
end
-- Look for disamiguation template in page content
local title = mw.title.new(page)
if not title then return false end
local content = title:getContent()
return p.isDisambiguation(content)
end
-- Entry points for templates
p.isDisambiguationPage = function(frame)
local title = frame.args[1]
return p._isDisambiguationPage(title) and "yes" or ""
end
return p
8095747d2821274b0f3dbe8e4bfff65ac7787407
Module:Disambiguation/doc
828
323
417
2025-08-21T16:08:23Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Module:Disambiguation|Module and documentation on Wikipedia]] <includeonly>{{Sandbox other|| [[Category:Utility modules]] }}</includeonly> <noinclude>[[Category:Module documentation pages]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Module:Disambiguation|Module and documentation on Wikipedia]]
<includeonly>{{Sandbox other||
[[Category:Utility modules]]
}}</includeonly>
<noinclude>[[Category:Module documentation pages]]</noinclude>
0f383624152331145768651c39cb19c828697ea9
MediaWiki:Sidebar
8
324
418
2025-08-21T16:21:20Z
Sharparam
284703
Add import and export links
wikitext
text/x-wiki
* navigation
** mainpage|mainpage-description
** recentchanges-url|recentchanges
** randompage-url|randompage
** helppage|help-mediawiki
* sidebar-customizing-wiki
** MediaWiki:Sidebar|sidebar-edit-sidebar
** MediaWiki:Common.css|sidebar-edit-common-css
** MediaWiki:Vector.css|sidebar-edit-vector-css
** MediaWiki:Common.js|sidebar-edit-common-js
** Special:Gadgets|sidebar-gadgets
** Special:Import|sidebar-special-import
** Special:Export|sidebar-special-export
** Special:AllPages|sidebar-all-pages
** Special:SpecialPages|sidebar-special-pages
* wiki.gg
** support:|sidebar-support-wiki
** Wikigg-ticket-link|sidebar-submit-ticket
** wikigg-socialmedia-joinlink|wikigg-socialmedia-jointext-sidebar
4650a34e226dda6dd5e60c0168ab899130e28b31
MediaWiki:Sidebar-special-import
8
325
419
2025-08-21T16:22:53Z
Sharparam
284703
Created page with "Import"
wikitext
text/x-wiki
Import
d6fbc9d2bdd580e18ed0bc5805dc26db323d6f5f
MediaWiki:Sidebar-special-export
8
326
420
2025-08-21T16:23:11Z
Sharparam
284703
Created page with "Export"
wikitext
text/x-wiki
Export
f3e4fadb9e370a1e2c0c622c01fc8c77daf93a2c
Module:Exponential search
828
327
422
421
2025-08-21T16:23:41Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
-- This module provides a generic exponential search algorithm.
require[[strict]]
local checkType = require('libraryUtil').checkType
local floor = math.floor
local function midPoint(lower, upper)
return floor(lower + (upper - lower) / 2)
end
local function search(testFunc, i, lower, upper)
if testFunc(i) then
if i + 1 == upper then
return i
end
lower = i
if upper then
i = midPoint(lower, upper)
else
i = i * 2
end
return search(testFunc, i, lower, upper)
else
upper = i
i = midPoint(lower, upper)
return search(testFunc, i, lower, upper)
end
end
return function (testFunc, init)
checkType('Exponential search', 1, testFunc, 'function')
checkType('Exponential search', 2, init, 'number', true)
if init and (init < 1 or init ~= floor(init) or init == math.huge) then
error(string.format(
"invalid init value '%s' detected in argument #2 to " ..
"'Exponential search' (init value must be a positive integer)",
tostring(init)
), 2)
end
init = init or 2
if not testFunc(1) then
return nil
end
return search(testFunc, init, 1, nil)
end
a9037be0c44536be79b2d7a26155bfb907368ae7
Module:TableTools
828
328
424
423
2025-08-21T16:23:42Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
------------------------------------------------------------------------------------
-- TableTools --
-- --
-- This module includes a number of functions for dealing with Lua tables. --
-- It is a meta-module, meant to be called from other Lua modules, and should not --
-- be called directly from #invoke. --
------------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local p = {}
-- Define often-used variables and functions.
local floor = math.floor
local infinity = math.huge
local checkType = libraryUtil.checkType
local checkTypeMulti = libraryUtil.checkTypeMulti
------------------------------------------------------------------------------------
-- isPositiveInteger
--
-- This function returns true if the given value is a positive integer, and false
-- if not. Although it doesn't operate on tables, it is included here as it is
-- useful for determining whether a given table key is in the array part or the
-- hash part of a table.
------------------------------------------------------------------------------------
function p.isPositiveInteger(v)
return type(v) == 'number' and v >= 1 and floor(v) == v and v < infinity
end
------------------------------------------------------------------------------------
-- isNan
--
-- This function returns true if the given number is a NaN value, and false if
-- not. Although it doesn't operate on tables, it is included here as it is useful
-- for determining whether a value can be a valid table key. Lua will generate an
-- error if a NaN is used as a table key.
------------------------------------------------------------------------------------
function p.isNan(v)
return type(v) == 'number' and v ~= v
end
------------------------------------------------------------------------------------
-- shallowClone
--
-- This returns a clone of a table. The value returned is a new table, but all
-- subtables and functions are shared. Metamethods are respected, but the returned
-- table will have no metatable of its own.
------------------------------------------------------------------------------------
function p.shallowClone(t)
checkType('shallowClone', 1, t, 'table')
local ret = {}
for k, v in pairs(t) do
ret[k] = v
end
return ret
end
------------------------------------------------------------------------------------
-- removeDuplicates
--
-- This removes duplicate values from an array. Non-positive-integer keys are
-- ignored. The earliest value is kept, and all subsequent duplicate values are
-- removed, but otherwise the array order is unchanged.
------------------------------------------------------------------------------------
function p.removeDuplicates(arr)
checkType('removeDuplicates', 1, arr, 'table')
local isNan = p.isNan
local ret, exists = {}, {}
for _, v in ipairs(arr) do
if isNan(v) then
-- NaNs can't be table keys, and they are also unique, so we don't need to check existence.
ret[#ret + 1] = v
elseif not exists[v] then
ret[#ret + 1] = v
exists[v] = true
end
end
return ret
end
------------------------------------------------------------------------------------
-- numKeys
--
-- This takes a table and returns an array containing the numbers of any numerical
-- keys that have non-nil values, sorted in numerical order.
------------------------------------------------------------------------------------
function p.numKeys(t)
checkType('numKeys', 1, t, 'table')
local isPositiveInteger = p.isPositiveInteger
local nums = {}
for k in pairs(t) do
if isPositiveInteger(k) then
nums[#nums + 1] = k
end
end
table.sort(nums)
return nums
end
------------------------------------------------------------------------------------
-- affixNums
--
-- This takes a table and returns an array containing the numbers of keys with the
-- specified prefix and suffix. For example, for the table
-- {a1 = 'foo', a3 = 'bar', a6 = 'baz'} and the prefix "a", affixNums will return
-- {1, 3, 6}.
------------------------------------------------------------------------------------
function p.affixNums(t, prefix, suffix)
checkType('affixNums', 1, t, 'table')
checkType('affixNums', 2, prefix, 'string', true)
checkType('affixNums', 3, suffix, 'string', true)
local function cleanPattern(s)
-- Cleans a pattern so that the magic characters ()%.[]*+-?^$ are interpreted literally.
return s:gsub('([%(%)%%%.%[%]%*%+%-%?%^%$])', '%%%1')
end
prefix = prefix or ''
suffix = suffix or ''
prefix = cleanPattern(prefix)
suffix = cleanPattern(suffix)
local pattern = '^' .. prefix .. '([1-9]%d*)' .. suffix .. '$'
local nums = {}
for k in pairs(t) do
if type(k) == 'string' then
local num = mw.ustring.match(k, pattern)
if num then
nums[#nums + 1] = tonumber(num)
end
end
end
table.sort(nums)
return nums
end
------------------------------------------------------------------------------------
-- numData
--
-- Given a table with keys like {"foo1", "bar1", "foo2", "baz2"}, returns a table
-- of subtables in the format
-- {[1] = {foo = 'text', bar = 'text'}, [2] = {foo = 'text', baz = 'text'}}.
-- Keys that don't end with an integer are stored in a subtable named "other". The
-- compress option compresses the table so that it can be iterated over with
-- ipairs.
------------------------------------------------------------------------------------
function p.numData(t, compress)
checkType('numData', 1, t, 'table')
checkType('numData', 2, compress, 'boolean', true)
local ret = {}
for k, v in pairs(t) do
local prefix, num = mw.ustring.match(tostring(k), '^([^0-9]*)([1-9][0-9]*)$')
if num then
num = tonumber(num)
local subtable = ret[num] or {}
if prefix == '' then
-- Positional parameters match the blank string; put them at the start of the subtable instead.
prefix = 1
end
subtable[prefix] = v
ret[num] = subtable
else
local subtable = ret.other or {}
subtable[k] = v
ret.other = subtable
end
end
if compress then
local other = ret.other
ret = p.compressSparseArray(ret)
ret.other = other
end
return ret
end
------------------------------------------------------------------------------------
-- compressSparseArray
--
-- This takes an array with one or more nil values, and removes the nil values
-- while preserving the order, so that the array can be safely traversed with
-- ipairs.
------------------------------------------------------------------------------------
function p.compressSparseArray(t)
checkType('compressSparseArray', 1, t, 'table')
local ret = {}
local nums = p.numKeys(t)
for _, num in ipairs(nums) do
ret[#ret + 1] = t[num]
end
return ret
end
------------------------------------------------------------------------------------
-- sparseIpairs
--
-- This is an iterator for sparse arrays. It can be used like ipairs, but can
-- handle nil values.
------------------------------------------------------------------------------------
function p.sparseIpairs(t)
checkType('sparseIpairs', 1, t, 'table')
local nums = p.numKeys(t)
local i = 0
local lim = #nums
return function ()
i = i + 1
if i <= lim then
local key = nums[i]
return key, t[key]
else
return nil, nil
end
end
end
------------------------------------------------------------------------------------
-- size
--
-- This returns the size of a key/value pair table. It will also work on arrays,
-- but for arrays it is more efficient to use the # operator.
------------------------------------------------------------------------------------
function p.size(t)
checkType('size', 1, t, 'table')
local i = 0
for _ in pairs(t) do
i = i + 1
end
return i
end
local function defaultKeySort(item1, item2)
-- "number" < "string", so numbers will be sorted before strings.
local type1, type2 = type(item1), type(item2)
if type1 ~= type2 then
return type1 < type2
elseif type1 == 'table' or type1 == 'boolean' or type1 == 'function' then
return tostring(item1) < tostring(item2)
else
return item1 < item2
end
end
------------------------------------------------------------------------------------
-- keysToList
--
-- Returns an array of the keys in a table, sorted using either a default
-- comparison function or a custom keySort function.
------------------------------------------------------------------------------------
function p.keysToList(t, keySort, checked)
if not checked then
checkType('keysToList', 1, t, 'table')
checkTypeMulti('keysToList', 2, keySort, {'function', 'boolean', 'nil'})
end
local arr = {}
local index = 1
for k in pairs(t) do
arr[index] = k
index = index + 1
end
if keySort ~= false then
keySort = type(keySort) == 'function' and keySort or defaultKeySort
table.sort(arr, keySort)
end
return arr
end
------------------------------------------------------------------------------------
-- sortedPairs
--
-- Iterates through a table, with the keys sorted using the keysToList function.
-- If there are only numerical keys, sparseIpairs is probably more efficient.
------------------------------------------------------------------------------------
function p.sortedPairs(t, keySort)
checkType('sortedPairs', 1, t, 'table')
checkType('sortedPairs', 2, keySort, 'function', true)
local arr = p.keysToList(t, keySort, true)
local i = 0
return function ()
i = i + 1
local key = arr[i]
if key ~= nil then
return key, t[key]
else
return nil, nil
end
end
end
------------------------------------------------------------------------------------
-- isArray
--
-- Returns true if the given value is a table and all keys are consecutive
-- integers starting at 1.
------------------------------------------------------------------------------------
function p.isArray(v)
if type(v) ~= 'table' then
return false
end
local i = 0
for _ in pairs(v) do
i = i + 1
if v[i] == nil then
return false
end
end
return true
end
------------------------------------------------------------------------------------
-- isArrayLike
--
-- Returns true if the given value is iterable and all keys are consecutive
-- integers starting at 1.
------------------------------------------------------------------------------------
function p.isArrayLike(v)
if not pcall(pairs, v) then
return false
end
local i = 0
for _ in pairs(v) do
i = i + 1
if v[i] == nil then
return false
end
end
return true
end
------------------------------------------------------------------------------------
-- invert
--
-- Transposes the keys and values in an array. For example, {"a", "b", "c"} ->
-- {a = 1, b = 2, c = 3}. Duplicates are not supported (result values refer to
-- the index of the last duplicate) and NaN values are ignored.
------------------------------------------------------------------------------------
function p.invert(arr)
checkType("invert", 1, arr, "table")
local isNan = p.isNan
local map = {}
for i, v in ipairs(arr) do
if not isNan(v) then
map[v] = i
end
end
return map
end
------------------------------------------------------------------------------------
-- listToSet
--
-- Creates a set from the array part of the table. Indexing the set by any of the
-- values of the array returns true. For example, {"a", "b", "c"} ->
-- {a = true, b = true, c = true}. NaN values are ignored as Lua considers them
-- never equal to any value (including other NaNs or even themselves).
------------------------------------------------------------------------------------
function p.listToSet(arr)
checkType("listToSet", 1, arr, "table")
local isNan = p.isNan
local set = {}
for _, v in ipairs(arr) do
if not isNan(v) then
set[v] = true
end
end
return set
end
------------------------------------------------------------------------------------
-- deepCopy
--
-- Recursive deep copy function. Preserves identities of subtables.
------------------------------------------------------------------------------------
local function _deepCopy(orig, includeMetatable, already_seen)
if type(orig) ~= "table" then
return orig
end
-- already_seen stores copies of tables indexed by the original table.
local copy = already_seen[orig]
if copy ~= nil then
return copy
end
copy = {}
already_seen[orig] = copy -- memoize before any recursion, to avoid infinite loops
for orig_key, orig_value in pairs(orig) do
copy[_deepCopy(orig_key, includeMetatable, already_seen)] = _deepCopy(orig_value, includeMetatable, already_seen)
end
if includeMetatable then
local mt = getmetatable(orig)
if mt ~= nil then
setmetatable(copy, _deepCopy(mt, true, already_seen))
end
end
return copy
end
function p.deepCopy(orig, noMetatable, already_seen)
checkType("deepCopy", 3, already_seen, "table", true)
return _deepCopy(orig, not noMetatable, already_seen or {})
end
------------------------------------------------------------------------------------
-- sparseConcat
--
-- Concatenates all values in the table that are indexed by a number, in order.
-- sparseConcat{a, nil, c, d} => "acd"
-- sparseConcat{nil, b, c, d} => "bcd"
------------------------------------------------------------------------------------
function p.sparseConcat(t, sep, i, j)
local arr = {}
local arr_i = 0
for _, v in p.sparseIpairs(t) do
arr_i = arr_i + 1
arr[arr_i] = v
end
return table.concat(arr, sep, i, j)
end
------------------------------------------------------------------------------------
-- length
--
-- Finds the length of an array, or of a quasi-array with keys such as "data1",
-- "data2", etc., using an exponential search algorithm. It is similar to the
-- operator #, but may return a different value when there are gaps in the array
-- portion of the table. Intended to be used on data loaded with mw.loadData. For
-- other tables, use #.
-- Note: #frame.args in frame object always be set to 0, regardless of the number
-- of unnamed template parameters, so use this function for frame.args.
------------------------------------------------------------------------------------
function p.length(t, prefix)
-- requiring module inline so that [[Module:Exponential search]] which is
-- only needed by this one function doesn't get millions of transclusions
local expSearch = require("Module:Exponential search")
checkType('length', 1, t, 'table')
checkType('length', 2, prefix, 'string', true)
return expSearch(function (i)
local key
if prefix then
key = prefix .. tostring(i)
else
key = i
end
return t[key] ~= nil
end) or 0
end
------------------------------------------------------------------------------------
-- inArray
--
-- Returns true if searchElement is a member of the array, and false otherwise.
-- Equivalent to JavaScript array.includes(searchElement) or
-- array.includes(searchElement, fromIndex), except fromIndex is 1 indexed
------------------------------------------------------------------------------------
function p.inArray(array, searchElement, fromIndex)
checkType("inArray", 1, array, "table")
-- if searchElement is nil, error?
fromIndex = tonumber(fromIndex)
if fromIndex then
if (fromIndex < 0) then
fromIndex = #array + fromIndex + 1
end
if fromIndex < 1 then fromIndex = 1 end
for _, v in ipairs({unpack(array, fromIndex)}) do
if v == searchElement then
return true
end
end
else
for _, v in pairs(array) do
if v == searchElement then
return true
end
end
end
return false
end
------------------------------------------------------------------------------------
-- merge
--
-- Given the arrays, returns an array containing the elements of each input array
-- in sequence.
------------------------------------------------------------------------------------
function p.merge(...)
local arrays = {...}
local ret = {}
for i, arr in ipairs(arrays) do
checkType('merge', i, arr, 'table')
for _, v in ipairs(arr) do
ret[#ret + 1] = v
end
end
return ret
end
------------------------------------------------------------------------------------
-- extend
--
-- Extends the first array in place by appending all elements from the second
-- array.
------------------------------------------------------------------------------------
function p.extend(arr1, arr2)
checkType('extend', 1, arr1, 'table')
checkType('extend', 2, arr2, 'table')
for _, v in ipairs(arr2) do
arr1[#arr1 + 1] = v
end
end
return p
27b6a4e23d902c05ad6e005059248318bffc2a4e
Module:Namespace detect
828
329
426
425
2025-08-21T16:23:42Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--[[
--------------------------------------------------------------------------------
-- --
-- NAMESPACE DETECT --
-- --
-- This module implements the {{namespace detect}} template in Lua, with a --
-- few improvements: all namespaces and all namespace aliases are supported, --
-- and namespace names are detected automatically for the local wiki. The --
-- module can also use the corresponding subject namespace value if it is --
-- used on a talk page. Parameter names can be configured for different wikis --
-- by altering the values in the "cfg" table in --
-- Module:Namespace detect/config. --
-- --
--------------------------------------------------------------------------------
--]]
local data = mw.loadData('Module:Namespace detect/data')
local argKeys = data.argKeys
local cfg = data.cfg
local mappings = data.mappings
local yesno = require('Module:Yesno')
local mArguments -- Lazily initialise Module:Arguments
local mTableTools -- Lazily initilalise Module:TableTools
local ustringLower = mw.ustring.lower
local p = {}
local function fetchValue(t1, t2)
-- Fetches a value from the table t1 for the first key in array t2 where
-- a non-nil value of t1 exists.
for i, key in ipairs(t2) do
local value = t1[key]
if value ~= nil then
return value
end
end
return nil
end
local function equalsArrayValue(t, value)
-- Returns true if value equals a value in the array t. Otherwise
-- returns false.
for i, arrayValue in ipairs(t) do
if value == arrayValue then
return true
end
end
return false
end
function p.getPageObject(page)
-- Get the page object, passing the function through pcall in case of
-- errors, e.g. being over the expensive function count limit.
if page then
local success, pageObject = pcall(mw.title.new, page)
if success then
return pageObject
else
return nil
end
else
return mw.title.getCurrentTitle()
end
end
-- Provided for backward compatibility with other modules
function p.getParamMappings()
return mappings
end
local function getNamespace(args)
-- This function gets the namespace name from the page object.
local page = fetchValue(args, argKeys.demopage)
if page == '' then
page = nil
end
local demospace = fetchValue(args, argKeys.demospace)
if demospace == '' then
demospace = nil
end
local subjectns = fetchValue(args, argKeys.subjectns)
local ret
if demospace then
-- Handle "demospace = main" properly.
if equalsArrayValue(argKeys.main, ustringLower(demospace)) then
ret = mw.site.namespaces[0].name
else
ret = demospace
end
else
local pageObject = p.getPageObject(page)
if pageObject then
if pageObject.isTalkPage then
-- Get the subject namespace if the option is set,
-- otherwise use "talk".
if yesno(subjectns) then
ret = mw.site.namespaces[pageObject.namespace].subject.name
else
ret = 'talk'
end
else
ret = pageObject.nsText
end
else
return nil -- return nil if the page object doesn't exist.
end
end
ret = ret:gsub('_', ' ')
return ustringLower(ret)
end
function p._main(args)
-- Check the parameters stored in the mappings table for any matches.
local namespace = getNamespace(args) or 'other' -- "other" avoids nil table keys
local params = mappings[namespace] or {}
local ret = fetchValue(args, params)
--[[
-- If there were no matches, return parameters for other namespaces.
-- This happens if there was no text specified for the namespace that
-- was detected or if the demospace parameter is not a valid
-- namespace. Note that the parameter for the detected namespace must be
-- completely absent for this to happen, not merely blank.
--]]
if ret == nil then
ret = fetchValue(args, argKeys.other)
end
return ret
end
function p.main(frame)
mArguments = require('Module:Arguments')
local args = mArguments.getArgs(frame, {removeBlanks = false})
local ret = p._main(args)
return ret or ''
end
function p.table(frame)
--[[
-- Create a wikitable of all subject namespace parameters, for
-- documentation purposes. The talk parameter is optional, in case it
-- needs to be excluded in the documentation.
--]]
-- Load modules and initialise variables.
mTableTools = require('Module:TableTools')
local namespaces = mw.site.namespaces
local cfg = data.cfg
local useTalk = type(frame) == 'table'
and type(frame.args) == 'table'
and yesno(frame.args.talk) -- Whether to use the talk parameter.
-- Get the header names.
local function checkValue(value, default)
if type(value) == 'string' then
return value
else
return default
end
end
local nsHeader = checkValue(cfg.wikitableNamespaceHeader, 'Namespace')
local aliasesHeader = checkValue(cfg.wikitableAliasesHeader, 'Aliases')
-- Put the namespaces in order.
local mappingsOrdered = {}
for nsname, params in pairs(mappings) do
if useTalk or nsname ~= 'talk' then
local nsid = namespaces[nsname].id
-- Add 1, as the array must start with 1; nsid 0 would be lost otherwise.
nsid = nsid + 1
mappingsOrdered[nsid] = params
end
end
mappingsOrdered = mTableTools.compressSparseArray(mappingsOrdered)
-- Build the table.
local ret = '{| class="wikitable"'
.. '\n|-'
.. '\n! ' .. nsHeader
.. '\n! ' .. aliasesHeader
for i, params in ipairs(mappingsOrdered) do
for j, param in ipairs(params) do
if j == 1 then
ret = ret .. '\n|-'
.. '\n| <code>' .. param .. '</code>'
.. '\n| '
elseif j == 2 then
ret = ret .. '<code>' .. param .. '</code>'
else
ret = ret .. ', <code>' .. param .. '</code>'
end
end
end
ret = ret .. '\n|-'
.. '\n|}'
return ret
end
return p
a4757000273064f151f0f22dc0e139092e5ff443
Module:Namespace detect/config
828
330
428
427
2025-08-21T16:23:42Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Namespace detect configuration data --
-- --
-- This module stores configuration data for Module:Namespace detect. Here --
-- you can localise the module to your wiki's language. --
-- --
-- To activate a configuration item, you need to uncomment it. This means --
-- that you need to remove the text "-- " at the start of the line. --
--------------------------------------------------------------------------------
local cfg = {} -- Don't edit this line.
--------------------------------------------------------------------------------
-- Parameter names --
-- These configuration items specify custom parameter names. Values added --
-- here will work in addition to the default English parameter names. --
-- To add one extra name, you can use this format: --
-- --
-- cfg.foo = 'parameter name' --
-- --
-- To add multiple names, you can use this format: --
-- --
-- cfg.foo = {'parameter name 1', 'parameter name 2', 'parameter name 3'} --
--------------------------------------------------------------------------------
---- This parameter displays content for the main namespace:
-- cfg.main = 'main'
---- This parameter displays in talk namespaces:
-- cfg.talk = 'talk'
---- This parameter displays content for "other" namespaces (namespaces for which
---- parameters have not been specified):
-- cfg.other = 'other'
---- This parameter makes talk pages behave as though they are the corresponding
---- subject namespace. Note that this parameter is used with [[Module:Yesno]].
---- Edit that module to change the default values of "yes", "no", etc.
-- cfg.subjectns = 'subjectns'
---- This parameter sets a demonstration namespace:
-- cfg.demospace = 'demospace'
---- This parameter sets a specific page to compare:
cfg.demopage = 'page'
--------------------------------------------------------------------------------
-- Table configuration --
-- These configuration items allow customisation of the "table" function, --
-- used to generate a table of possible parameters in the module --
-- documentation. --
--------------------------------------------------------------------------------
---- The header for the namespace column in the wikitable containing the list of
---- possible subject-space parameters.
-- cfg.wikitableNamespaceHeader = 'Namespace'
---- The header for the wikitable containing the list of possible subject-space
---- parameters.
-- cfg.wikitableAliasesHeader = 'Aliases'
--------------------------------------------------------------------------------
-- End of configuration data --
--------------------------------------------------------------------------------
return cfg -- Don't edit this line.
0e4ff08d13c4b664d66b32c232deb129b77c1a56
Module:Namespace detect/data
828
331
430
429
2025-08-21T16:23:42Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Namespace detect data --
-- This module holds data for [[Module:Namespace detect]] to be loaded per --
-- page, rather than per #invoke, for performance reasons. --
--------------------------------------------------------------------------------
local cfg = require('Module:Namespace detect/config')
local function addKey(t, key, defaultKey)
if key ~= defaultKey then
t[#t + 1] = key
end
end
-- Get a table of parameters to query for each default parameter name.
-- This allows wikis to customise parameter names in the cfg table while
-- ensuring that default parameter names will always work. The cfg table
-- values can be added as a string, or as an array of strings.
local defaultKeys = {
'main',
'talk',
'other',
'subjectns',
'demospace',
'demopage'
}
local argKeys = {}
for i, defaultKey in ipairs(defaultKeys) do
argKeys[defaultKey] = {defaultKey}
end
for defaultKey, t in pairs(argKeys) do
local cfgValue = cfg[defaultKey]
local cfgValueType = type(cfgValue)
if cfgValueType == 'string' then
addKey(t, cfgValue, defaultKey)
elseif cfgValueType == 'table' then
for i, key in ipairs(cfgValue) do
addKey(t, key, defaultKey)
end
end
cfg[defaultKey] = nil -- Free the cfg value as we don't need it any more.
end
local function getParamMappings()
--[[
-- Returns a table of how parameter names map to namespace names. The keys
-- are the actual namespace names, in lower case, and the values are the
-- possible parameter names for that namespace, also in lower case. The
-- table entries are structured like this:
-- {
-- [''] = {'main'},
-- ['wikipedia'] = {'wikipedia', 'project', 'wp'},
-- ...
-- }
--]]
local mappings = {}
local mainNsName = mw.site.subjectNamespaces[0].name
mainNsName = mw.ustring.lower(mainNsName)
mappings[mainNsName] = mw.clone(argKeys.main)
mappings['talk'] = mw.clone(argKeys.talk)
for nsid, ns in pairs(mw.site.subjectNamespaces) do
if nsid ~= 0 then -- Exclude main namespace.
local nsname = mw.ustring.lower(ns.name)
local canonicalName = mw.ustring.lower(ns.canonicalName)
mappings[nsname] = {nsname}
if canonicalName ~= nsname then
table.insert(mappings[nsname], canonicalName)
end
for _, alias in ipairs(ns.aliases) do
table.insert(mappings[nsname], mw.ustring.lower(alias))
end
end
end
return mappings
end
return {
argKeys = argKeys,
cfg = cfg,
mappings = getParamMappings()
}
d224f42a258bc308ef3ad8cc8686cd7a4f47d005
Module:Pagetype
828
332
432
431
2025-08-21T16:23:42Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- --
-- This meta-module which automatically detects namespaces, and allows --
-- for a great deal of customisation. It can easily be ported to other --
-- wikis by changing the values in the [[Module:Pagetype/config]]. --
-- --
--------------------------------------------------------------------------------
-- Load config.
local cfg = mw.loadData('Module:Pagetype/config')
-- Load required modules.
local yesno = require('Module:Yesno')
local p = {}
-- Look up a namespace argument in the args table.
local function lookUpNamespaceArg(args, key)
local arg = args[key]
-- Convert "yes", "1" etc. to true, "no", "0" etc. to false, and leave
-- other values the same.
return yesno(arg, arg)
end
-- Append multiple values to an array
local function appendMultiple(target, source)
for _, value in ipairs(source) do
table.insert(target, value)
end
end
-- Get argument keys for a title's namespace
local function getNamespaceArgKeys(title)
local nsInfo = mw.site.namespaces[title.namespace]
local customAliases = cfg.customNamespaceAliases[title.namespace] or {}
local keys = {}
if nsInfo.name ~= '' then
table.insert(keys, nsInfo.name)
end
if nsInfo.canonicalName ~= nsInfo.name and nsInfo.canonicalName ~= '' then
table.insert(keys, nsInfo.canonicalName)
end
appendMultiple(keys, nsInfo.aliases)
appendMultiple(keys, customAliases)
return keys
end
-- Get the argument for a title's namespace, if it was specified in the args table.
local function getNamespaceArg(title, args)
if title.isTalkPage then
return lookUpNamespaceArg(args, cfg.talk)
end
for _, key in ipairs(getNamespaceArgKeys(title)) do
local arg = lookUpNamespaceArg(args, mw.ustring.lower(key))
if arg ~= nil then
return arg
end
end
return nil
end
-- Look up a page type specific to the title's namespace
local function getExplicitPageType(title)
if title.isTalkPage then
return cfg.talkDefault
else
return cfg.pagetypes[title.namespace]
end
end
-- Get a default page type that is not specific to the title's namespace
local function getDefaultPageType(args)
local other = lookUpNamespaceArg(args, cfg.other)
if type(other) == 'string' then
return other
else
return cfg.otherDefault
end
end
local function detectRedirects(title, args)
local redirect = lookUpNamespaceArg(args, cfg.redirect)
if redirect == false then
-- Don't detect redirects if they have been specifically disallowed.
return nil
end
-- Allow custom values for redirects.
if not title.isRedirect then
return nil
elseif type(redirect) == 'string' then
return redirect
else
return cfg.redirectDefault
end
end
local function capitalize(pageType)
local first = mw.ustring.sub(pageType, 1, 1)
local rest = mw.ustring.sub(pageType, 2)
return mw.ustring.upper(first) .. rest
end
local function pluralize(pageType)
if cfg.irregularPlurals[pageType] then
return cfg.irregularPlurals[pageType]
else
return pageType .. cfg.plural -- often 's'
end
end
local function parseContent(title, args, optionsList)
if title.namespace==828 and title.subpageText~='doc' -- don't detect modules
or not title.exists -- can't check unless page exists
then
return nil
end
local content = title:getContent()
if content == nil then
return nil
end
local templates -- lazily evaluated
for _, options in next, optionsList do
local list, parameter, default, articleOnly = unpack(options, 1, 4)
if not articleOnly or title.namespace==0 then -- only check for templates if we should...
local out = lookUpNamespaceArg(args, parameter)
if type(out) == "string" or (out ~= false and default) then -- ...and if we actually have anything to say about them
if not templates then
templates = {} -- do our delayed evaluation now that we are required to
content = require('Module:Wikitext Parsing').PrepareText(content) -- disregard templates which do not have any affect
for template in string.gmatch(content, "{{%s*([^|}]-)%s*[|}]") do
templates[#templates+1] = capitalize(template)
end
end
local wantedTemplates = mw.loadData('Module:Pagetype/' .. list)
local templateFound = false
for _, template in next, templates do
if wantedTemplates[template] then
templateFound = true
break
end
end
if templateFound then
if type(out)=='string' then
return out
elseif out ~= false and default then
return default
end
end
end
end
end
end
-- Find pages which do not exist
local function nonExistent(title, args)
local arg = lookUpNamespaceArg(args, cfg.ne)
if arg == false then
return nil
end
local exists = false
if title.exists then -- not an article if it does not exist
exists = true
elseif title.namespace==8 and mw.message.new(title.text):exists() then
exists = true
elseif title.namespace==6 and title.fileExists then
exists = true
end
if not exists then
if type(arg) == 'string' then
return arg
else
return cfg.naDefault
end
end
end
-- Get page types for mainspaces pages with an explicit class specified
local function getMainNamespaceClassPageType(title, args)
local class = args[1]
if type(class) == 'string' then -- Put in lower case so e.g. "na" and "NA" will both match
class = mw.ustring.lower(class)
end
local arg = lookUpNamespaceArg(args, cfg.na)
if arg == false then -- don't check for this class if it is specifically disallowed
return nil
end
if cfg.naAliases[class] then
if type(arg) == 'string' then
return arg
else
return cfg.naDefault
end
else
return nil
end
end
-- Get page type specified by an explicit namespace argument.
local function getNamespaceArgPageType(title, args)
local namespaceArg = getNamespaceArg(title, args)
if namespaceArg == true then
-- Namespace has been explicitly enabled, so return the default for
-- this namespace
return getExplicitPageType(title)
elseif namespaceArg == false then
-- Namespace has been explicitly disabled
return getDefaultPageType(args)
elseif namespaceArg then
-- This namespaces uses custom text
return namespaceArg
else
return nil
end
end
-- Get page type not specified or detected by other means
local function getOtherPageType(title, args)
-- Whether the title is in the set of default active namespaces which are looked up in cfg.pagetypes.
local isInDefaultActiveNamespace = false
local defaultNamespacesKey = args[cfg.defaultns]
if defaultNamespacesKey == cfg.defaultnsAll then
isInDefaultActiveNamespace = true
else
local defaultNamespaces
if defaultNamespacesKey == cfg.defaultnsExtended then
defaultNamespaces = cfg.extendedNamespaces
elseif defaultNamespacesKey == cfg.defaultnsNone then
defaultNamespaces = {}
else
defaultNamespaces = cfg.defaultNamespaces
end
isInDefaultActiveNamespace = defaultNamespaces[title.namespace]
end
if isInDefaultActiveNamespace then
return getExplicitPageType(title)
else
return getDefaultPageType(args)
end
end
function p._main(args)
local title
if args.page then
title = mw.title.new(args.page)
else
title = mw.title.getCurrentTitle()
end
if title and not yesno(args.talk, true) and args[cfg.defaultns] ~= cfg.defaultnsAll then
title = title.subjectPageTitle
end
local pageType = detectRedirects(title, args)
or nonExistent(title, args)
or parseContent(title, args, {
{'softredirect', cfg.softRedirect, cfg.softRedirectDefault},
{'setindex', cfg.sia, cfg.siaDefault, true},
{'disambiguation', cfg.dab, cfg.dabDefault, true},
{'rfd', cfg.rfd, cfg.rfdDefault},
})
or (title.namespace == 0 and getMainNamespaceClassPageType(title, args))
or getNamespaceArgPageType(title, args)
or getOtherPageType(title, args)
if yesno(args.plural, false) then
pageType = pluralize(pageType)
end
if yesno(args.caps, false) then
pageType = capitalize(pageType)
end
return pageType
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame)
return p._main(args)
end
return p
cb47b460d74d5df739ee7e300eeae512798bc475
451
432
2025-08-21T16:33:26Z
Sharparam
284703
Disable some unused types
Scribunto
text/plain
--------------------------------------------------------------------------------
-- --
-- This meta-module which automatically detects namespaces, and allows --
-- for a great deal of customisation. It can easily be ported to other --
-- wikis by changing the values in the [[Module:Pagetype/config]]. --
-- --
--------------------------------------------------------------------------------
-- Load config.
local cfg = mw.loadData('Module:Pagetype/config')
-- Load required modules.
local yesno = require('Module:Yesno')
local p = {}
-- Look up a namespace argument in the args table.
local function lookUpNamespaceArg(args, key)
local arg = args[key]
-- Convert "yes", "1" etc. to true, "no", "0" etc. to false, and leave
-- other values the same.
return yesno(arg, arg)
end
-- Append multiple values to an array
local function appendMultiple(target, source)
for _, value in ipairs(source) do
table.insert(target, value)
end
end
-- Get argument keys for a title's namespace
local function getNamespaceArgKeys(title)
local nsInfo = mw.site.namespaces[title.namespace]
local customAliases = cfg.customNamespaceAliases[title.namespace] or {}
local keys = {}
if nsInfo.name ~= '' then
table.insert(keys, nsInfo.name)
end
if nsInfo.canonicalName ~= nsInfo.name and nsInfo.canonicalName ~= '' then
table.insert(keys, nsInfo.canonicalName)
end
appendMultiple(keys, nsInfo.aliases)
appendMultiple(keys, customAliases)
return keys
end
-- Get the argument for a title's namespace, if it was specified in the args table.
local function getNamespaceArg(title, args)
if title.isTalkPage then
return lookUpNamespaceArg(args, cfg.talk)
end
for _, key in ipairs(getNamespaceArgKeys(title)) do
local arg = lookUpNamespaceArg(args, mw.ustring.lower(key))
if arg ~= nil then
return arg
end
end
return nil
end
-- Look up a page type specific to the title's namespace
local function getExplicitPageType(title)
if title.isTalkPage then
return cfg.talkDefault
else
return cfg.pagetypes[title.namespace]
end
end
-- Get a default page type that is not specific to the title's namespace
local function getDefaultPageType(args)
local other = lookUpNamespaceArg(args, cfg.other)
if type(other) == 'string' then
return other
else
return cfg.otherDefault
end
end
local function detectRedirects(title, args)
local redirect = lookUpNamespaceArg(args, cfg.redirect)
if redirect == false then
-- Don't detect redirects if they have been specifically disallowed.
return nil
end
-- Allow custom values for redirects.
if not title.isRedirect then
return nil
elseif type(redirect) == 'string' then
return redirect
else
return cfg.redirectDefault
end
end
local function capitalize(pageType)
local first = mw.ustring.sub(pageType, 1, 1)
local rest = mw.ustring.sub(pageType, 2)
return mw.ustring.upper(first) .. rest
end
local function pluralize(pageType)
if cfg.irregularPlurals[pageType] then
return cfg.irregularPlurals[pageType]
else
return pageType .. cfg.plural -- often 's'
end
end
local function parseContent(title, args, optionsList)
if title.namespace==828 and title.subpageText~='doc' -- don't detect modules
or not title.exists -- can't check unless page exists
then
return nil
end
local content = title:getContent()
if content == nil then
return nil
end
local templates -- lazily evaluated
for _, options in next, optionsList do
local list, parameter, default, articleOnly = unpack(options, 1, 4)
if not articleOnly or title.namespace==0 then -- only check for templates if we should...
local out = lookUpNamespaceArg(args, parameter)
if type(out) == "string" or (out ~= false and default) then -- ...and if we actually have anything to say about them
if not templates then
templates = {} -- do our delayed evaluation now that we are required to
content = require('Module:Wikitext Parsing').PrepareText(content) -- disregard templates which do not have any affect
for template in string.gmatch(content, "{{%s*([^|}]-)%s*[|}]") do
templates[#templates+1] = capitalize(template)
end
end
local wantedTemplates = mw.loadData('Module:Pagetype/' .. list)
local templateFound = false
for _, template in next, templates do
if wantedTemplates[template] then
templateFound = true
break
end
end
if templateFound then
if type(out)=='string' then
return out
elseif out ~= false and default then
return default
end
end
end
end
end
end
-- Find pages which do not exist
local function nonExistent(title, args)
local arg = lookUpNamespaceArg(args, cfg.ne)
if arg == false then
return nil
end
local exists = false
if title.exists then -- not an article if it does not exist
exists = true
elseif title.namespace==8 and mw.message.new(title.text):exists() then
exists = true
elseif title.namespace==6 and title.fileExists then
exists = true
end
if not exists then
if type(arg) == 'string' then
return arg
else
return cfg.naDefault
end
end
end
-- Get page types for mainspaces pages with an explicit class specified
local function getMainNamespaceClassPageType(title, args)
local class = args[1]
if type(class) == 'string' then -- Put in lower case so e.g. "na" and "NA" will both match
class = mw.ustring.lower(class)
end
local arg = lookUpNamespaceArg(args, cfg.na)
if arg == false then -- don't check for this class if it is specifically disallowed
return nil
end
if cfg.naAliases[class] then
if type(arg) == 'string' then
return arg
else
return cfg.naDefault
end
else
return nil
end
end
-- Get page type specified by an explicit namespace argument.
local function getNamespaceArgPageType(title, args)
local namespaceArg = getNamespaceArg(title, args)
if namespaceArg == true then
-- Namespace has been explicitly enabled, so return the default for
-- this namespace
return getExplicitPageType(title)
elseif namespaceArg == false then
-- Namespace has been explicitly disabled
return getDefaultPageType(args)
elseif namespaceArg then
-- This namespaces uses custom text
return namespaceArg
else
return nil
end
end
-- Get page type not specified or detected by other means
local function getOtherPageType(title, args)
-- Whether the title is in the set of default active namespaces which are looked up in cfg.pagetypes.
local isInDefaultActiveNamespace = false
local defaultNamespacesKey = args[cfg.defaultns]
if defaultNamespacesKey == cfg.defaultnsAll then
isInDefaultActiveNamespace = true
else
local defaultNamespaces
if defaultNamespacesKey == cfg.defaultnsExtended then
defaultNamespaces = cfg.extendedNamespaces
elseif defaultNamespacesKey == cfg.defaultnsNone then
defaultNamespaces = {}
else
defaultNamespaces = cfg.defaultNamespaces
end
isInDefaultActiveNamespace = defaultNamespaces[title.namespace]
end
if isInDefaultActiveNamespace then
return getExplicitPageType(title)
else
return getDefaultPageType(args)
end
end
function p._main(args)
local title
if args.page then
title = mw.title.new(args.page)
else
title = mw.title.getCurrentTitle()
end
if title and not yesno(args.talk, true) and args[cfg.defaultns] ~= cfg.defaultnsAll then
title = title.subjectPageTitle
end
local pageType = detectRedirects(title, args)
or nonExistent(title, args)
or parseContent(title, args, {
{'softredirect', cfg.softRedirect, cfg.softRedirectDefault},
-- {'setindex', cfg.sia, cfg.siaDefault, true},
{'disambiguation', cfg.dab, cfg.dabDefault, true},
-- {'rfd', cfg.rfd, cfg.rfdDefault},
})
or (title.namespace == 0 and getMainNamespaceClassPageType(title, args))
or getNamespaceArgPageType(title, args)
or getOtherPageType(title, args)
if yesno(args.plural, false) then
pageType = pluralize(pageType)
end
if yesno(args.caps, false) then
pageType = capitalize(pageType)
end
return pageType
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame)
return p._main(args)
end
return p
fadbfaea763964bc8d117a6fa7f890efde4cbf12
Module:Pagetype/config
828
333
434
433
2025-08-21T16:23:43Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Pagetype configuration data --
-- This page holds localisation and configuration data for Module:Pagetype. --
--------------------------------------------------------------------------------
local cfg = {} -- Don't edit this line.
--------------------------------------------------------------------------------
-- Start configuration data --
--------------------------------------------------------------------------------
-- This table holds the default page types for each namespace. Keys to this
-- table should be integers that can be used as keys to mw.site.namespaces.
cfg.pagetypes = {
[0] = 'article', -- Main namespace
[2] = 'user page',
[4] = 'project page',
[6] = 'file',
[8] = 'interface page', -- MediaWiki namespace
[10] = 'template',
[12] = 'help page',
[14] = 'category',
[100] = 'portal',
[118] = 'draft',
[710] = 'Timed Text page',
[828] = 'module',
[2300] = 'gadget',
[2302] = 'gadget definition',
[-1] = 'special page',
[-2] = 'file', -- Media namespace
}
-- This table holds the namespaces to be looked up from cfg.pagetypes by
-- default.
cfg.defaultNamespaces = {
[0] = true, -- main
[6] = true, -- file
[10] = true, -- template
[14] = true, -- category
[828] = true, -- module
}
-- This table holds the namespaces to be looked up from cfg.pagetypes if
-- cfg.defaultnsExtended is set.
cfg.extendedNamespaces = {
[0] = true, -- main
[2] = true, -- user
[4] = true, -- project
[6] = true, -- file
[8] = true, -- mediawiki
[10] = true, -- template
[12] = true, -- help
[14] = true, -- category
[100] = true, -- portal
[118] = true, -- draft
[828] = true, -- module
}
-- This table holds custom aliases for each namespace.
cfg.customNamespaceAliases = {
[0] = {'main'},
}
-- The parameter name to set which default namespace values to be looked up from
-- cfg.pagetypes.
cfg.defaultns = 'defaultns'
-- The value of cfg.defaultns to set all namespaces, including talk.
cfg.defaultnsAll = 'all'
-- The value of cfg.defaultns to set the namespaces listed in
-- cfg.extendedNamespaces
cfg.defaultnsExtended = 'extended'
-- The value of cfg.defaultns to set no default namespaces.
cfg.defaultnsNone = 'none'
-- The parameter name to use for talk pages.
cfg.talk = 'talk'
-- The default value for talk pages.
cfg.talkDefault = 'talk page'
-- The parameter name to use for disambiguation pages page.
cfg.dab = 'dab'
-- The parameter name to use for non-existent pages.
cfg.ne = 'nonexistent'
cfg.neDefault = 'page'
cfg.softRedirect = 'soft_redirect'
cfg.softRedirectDefault = 'redirect'
cfg.sia = 'sia'
cfg.siaDefault = 'article'
cfg.rfd = 'redirect'
cfg.rfdDefault = 'redirect'
-- This table holds the different possible aliases for disambiguation-class
-- pages. These should be lower-case.
cfg.dabAliases = {
['disambiguation'] = true,
['disambig'] = true,
['disamb'] = true,
['dab'] = true,
}
-- The default value for disambiguation pages.
cfg.dabDefault = 'page'
-- The parameter name to use for N/A-class page.
cfg.na = 'na'
-- This table holds the different possible aliases for N/A-class pages. These
-- should be lower-case.
cfg.naAliases = {
['na'] = true,
['n/a'] = true,
}
-- The default value for N/A-class pages.
cfg.naDefault = 'page'
-- The parameter name to use for redirects.
cfg.redirect = 'redirect'
-- The default value to use for redirects.
cfg.redirectDefault = 'redirect'
-- The parameter name for undefined namespaces.
cfg.other = 'other'
-- The value used if the module detects an undefined namespace.
cfg.otherDefault = 'page'
-- The usual suffix denoting a plural.
cfg.plural = 's'
-- This table holds plurals not formed by a simple suffix.
cfg.irregularPlurals = {
["category"] = "categories"
}
--------------------------------------------------------------------------------
-- End configuration data --
--------------------------------------------------------------------------------
return cfg -- Don't edit this line
33b76bd60283986954f6a6203f163f6b304b95ee
Module:Error
828
334
436
435
2025-08-21T16:23:43Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
-- This module implements {{error}}.
local p = {}
local function _error(args)
local tag = mw.ustring.lower(tostring(args.tag))
-- Work out what html tag we should use.
if not (tag == 'p' or tag == 'span' or tag == 'div') then
tag = 'strong'
end
-- Generate the html.
return tostring(mw.html.create(tag)
:addClass('error')
:wikitext(tostring(args.message or args[1] or error('no message specified', 2)))
)
end
function p.error(frame)
local args
if type(frame.args) == 'table' then
-- We're being called via #invoke. The args are passed through to the module
-- from the template page, so use the args that were passed into the template.
args = frame.args
else
-- We're being called from another module or from the debug console, so assume
-- the args are passed in directly.
args = frame
end
-- if the message parameter is present but blank, change it to nil so that Lua will
-- consider it false.
if args.message == "" then
args.message = nil
end
return _error(args)
end
return p
f77bd720c216b5626efe795d3b49462d50971f7d
Template:Error
10
335
438
437
2025-08-21T16:23:43Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
wikitext
text/x-wiki
{{#invoke:Error|error|{{{message|{{{1}}}}}}|tag={{{tag|}}}}}<noinclude>
{{documentation}}
</noinclude>
5da54c14258c1b1755a03bccb88dc5d9d0cefb56
Module:Format link
828
336
440
439
2025-08-21T16:23:43Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Format link
--
-- Makes a wikilink from the given link and display values. Links are escaped
-- with colons if necessary, and links to sections are detected and displayed
-- with " § " as a separator rather than the standard MediaWiki "#". Used in
-- the {{format link}} template.
--------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local checkTypeForNamedArg = libraryUtil.checkTypeForNamedArg
local mArguments -- lazily initialise [[Module:Arguments]]
local mError -- lazily initialise [[Module:Error]]
local yesno -- lazily initialise [[Module:Yesno]]
local p = {}
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
local function getArgs(frame)
-- Fetches the arguments from the parent frame. Whitespace is trimmed and
-- blanks are removed.
mArguments = require('Module:Arguments')
return mArguments.getArgs(frame, {parentOnly = true})
end
local function removeInitialColon(s)
-- Removes the initial colon from a string, if present.
return s:match('^:?(.*)')
end
local function maybeItalicize(s, shouldItalicize)
-- Italicize s if s is a string and the shouldItalicize parameter is true.
if s and shouldItalicize then
return '<i>' .. s .. '</i>'
else
return s
end
end
local function parseLink(link)
-- Parse a link and return a table with the link's components.
-- These components are:
-- - link: the link, stripped of any initial colon (always present)
-- - page: the page name (always present)
-- - section: the page name (may be nil)
-- - display: the display text, if manually entered after a pipe (may be nil)
link = removeInitialColon(link)
-- Find whether a faux display value has been added with the {{!}} magic
-- word.
local prePipe, display = link:match('^(.-)|(.*)$')
link = prePipe or link
-- Find the page, if it exists.
-- For links like [[#Bar]], the page will be nil.
local preHash, postHash = link:match('^(.-)#(.*)$')
local page
if not preHash then
-- We have a link like [[Foo]].
page = link
elseif preHash ~= '' then
-- We have a link like [[Foo#Bar]].
page = preHash
end
-- Find the section, if it exists.
local section
if postHash and postHash ~= '' then
section = postHash
end
return {
link = link,
page = page,
section = section,
display = display,
}
end
local function formatDisplay(parsed, options)
-- Formats a display string based on a parsed link table (matching the
-- output of parseLink) and an options table (matching the input options for
-- _formatLink).
local page = maybeItalicize(parsed.page, options.italicizePage)
local section = maybeItalicize(parsed.section, options.italicizeSection)
if (not section) then
return page
elseif (not page) then
return mw.ustring.format('§ %s', section)
else
return mw.ustring.format('%s § %s', page, section)
end
end
local function missingArgError(target)
mError = require('Module:Error')
return mError.error{message =
'Error: no link or target specified! ([[' .. target .. '#Errors|help]])'
}
end
--------------------------------------------------------------------------------
-- Main functions
--------------------------------------------------------------------------------
function p.formatLink(frame)
-- The formatLink export function, for use in templates.
yesno = require('Module:Yesno')
local args = getArgs(frame)
local link = args[1] or args.link
local target = args[3] or args.target
if not (link or target) then
return missingArgError('Template:Format link')
end
return p._formatLink{
link = link,
display = args[2] or args.display,
target = target,
italicizePage = yesno(args.italicizepage),
italicizeSection = yesno(args.italicizesection),
categorizeMissing = args.categorizemissing
}
end
function p._formatLink(options)
-- The formatLink export function, for use in modules.
checkType('_formatLink', 1, options, 'table')
local function check(key, expectedType) --for brevity
checkTypeForNamedArg(
'_formatLink', key, options[key], expectedType or 'string', true
)
end
check('link')
check('display')
check('target')
check('italicizePage', 'boolean')
check('italicizeSection', 'boolean')
check('categorizeMissing')
-- Normalize link and target and check that at least one is present
if options.link == '' then options.link = nil end
if options.target == '' then options.target = nil end
if not (options.link or options.target) then
return missingArgError('Module:Format link')
end
local parsed = parseLink(options.link)
local display = options.display or parsed.display
local catMissing = options.categorizeMissing
local category = ''
-- Find the display text
if not display then display = formatDisplay(parsed, options) end
-- Handle the target option if present
if options.target then
local parsedTarget = parseLink(options.target)
parsed.link = parsedTarget.link
parsed.page = parsedTarget.page
end
-- Test if page exists if a diagnostic category is specified
if catMissing and (mw.ustring.len(catMissing) > 0) then
local title = nil
if parsed.page then title = mw.title.new(parsed.page) end
if title and (not title.isExternal) then
local success, exists = pcall(function() return title.exists end)
if success and not exists then
category = mw.ustring.format('[[Category:%s]]', catMissing)
end
end
end
-- Format the result as a link
if parsed.link == display then
return mw.ustring.format('[[:%s]]%s', parsed.link, category)
else
return mw.ustring.format('[[:%s|%s]]%s', parsed.link, display, category)
end
end
--------------------------------------------------------------------------------
-- Derived convenience functions
--------------------------------------------------------------------------------
function p.formatPages(options, pages)
-- Formats an array of pages using formatLink and the given options table,
-- and returns it as an array. Nil values are not allowed.
local ret = {}
for i, page in ipairs(pages) do
ret[i] = p._formatLink{
link = page,
categorizeMissing = options.categorizeMissing,
italicizePage = options.italicizePage,
italicizeSection = options.italicizeSection
}
end
return ret
end
return p
1253bdd2683ee4badc33856bfd5499b09a7dca1f
Module:Hatnote list
828
337
442
441
2025-08-21T16:23:43Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Hatnote list --
-- --
-- This module produces and formats lists for use in hatnotes. In particular, --
-- it implements the for-see list, i.e. lists of "For X, see Y" statements, --
-- as used in {{about}}, {{redirect}}, and their variants. Also introduced --
-- are andList & orList helpers for formatting lists with those conjunctions. --
--------------------------------------------------------------------------------
local mArguments --initialize lazily
local mFormatLink = require('Module:Format link')
local mHatnote = require('Module:Hatnote')
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
--------------------------------------------------------------------------------
-- List stringification helper functions
--
-- These functions are used for stringifying lists, usually page lists inside
-- the "Y" portion of "For X, see Y" for-see items.
--------------------------------------------------------------------------------
--default options table used across the list stringification functions
local stringifyListDefaultOptions = {
conjunction = "and",
separator = ",",
altSeparator = ";",
space = " ",
formatted = false
}
--Searches display text only
local function searchDisp(haystack, needle)
return string.find(
string.sub(haystack, (string.find(haystack, '|') or 0) + 1), needle
)
end
-- Stringifies a list generically; probably shouldn't be used directly
local function stringifyList(list, options)
-- Type-checks, defaults, and a shortcut
checkType("stringifyList", 1, list, "table")
if #list == 0 then return nil end
checkType("stringifyList", 2, options, "table", true)
options = options or {}
for k, v in pairs(stringifyListDefaultOptions) do
if options[k] == nil then options[k] = v end
end
local s = options.space
-- Format the list if requested
if options.formatted then
list = mFormatLink.formatPages(
{categorizeMissing = mHatnote.missingTargetCat}, list
)
end
-- Set the separator; if any item contains it, use the alternate separator
local separator = options.separator
for k, v in pairs(list) do
if searchDisp(v, separator) then
separator = options.altSeparator
break
end
end
-- Set the conjunction, apply Oxford comma, and force a comma if #1 has "§"
local conjunction = s .. options.conjunction .. s
if #list == 2 and searchDisp(list[1], "§") or #list > 2 then
conjunction = separator .. conjunction
end
-- Return the formatted string
return mw.text.listToText(list, separator .. s, conjunction)
end
--DRY function
function p.conjList (conj, list, fmt)
return stringifyList(list, {conjunction = conj, formatted = fmt})
end
-- Stringifies lists with "and" or "or"
function p.andList (...) return p.conjList("and", ...) end
function p.orList (...) return p.conjList("or", ...) end
--------------------------------------------------------------------------------
-- For see
--
-- Makes a "For X, see [[Y]]." list from raw parameters. Intended for the
-- {{about}} and {{redirect}} templates and their variants.
--------------------------------------------------------------------------------
--default options table used across the forSee family of functions
local forSeeDefaultOptions = {
andKeyword = 'and',
title = mw.title.getCurrentTitle().text,
otherText = 'other uses',
forSeeForm = 'For %s, see %s.',
}
--Collapses duplicate punctuation at end of string, ignoring italics and links
local function punctuationCollapse (text)
return text:match("[.?!]('?)%1(%]?)%2%.$") and text:sub(1, -2) or text
end
-- Structures arguments into a table for stringification, & options
function p.forSeeArgsToTable (args, from, options)
-- Type-checks and defaults
checkType("forSeeArgsToTable", 1, args, 'table')
checkType("forSeeArgsToTable", 2, from, 'number', true)
from = from or 1
checkType("forSeeArgsToTable", 3, options, 'table', true)
options = options or {}
for k, v in pairs(forSeeDefaultOptions) do
if options[k] == nil then options[k] = v end
end
-- maxArg's gotten manually because getArgs() and table.maxn aren't friends
local maxArg = 0
for k, v in pairs(args) do
if type(k) == 'number' and k > maxArg then maxArg = k end
end
-- Structure the data out from the parameter list:
-- * forTable is the wrapper table, with forRow rows
-- * Rows are tables of a "use" string & a "pages" table of pagename strings
-- * Blanks are left empty for defaulting elsewhere, but can terminate list
local forTable = {}
local i = from
local terminated = false
-- If there is extra text, and no arguments are given, give nil value
-- to not produce default of "For other uses, see foo (disambiguation)"
if options.extratext and i > maxArg then return nil end
-- Loop to generate rows
repeat
-- New empty row
local forRow = {}
-- On blank use, assume list's ended & break at end of this loop
forRow.use = args[i]
if not args[i] then terminated = true end
-- New empty list of pages
forRow.pages = {}
-- Insert first pages item if present
table.insert(forRow.pages, args[i + 1])
-- If the param after next is "and", do inner loop to collect params
-- until the "and"'s stop. Blanks are ignored: "1|and||and|3" → {1, 3}
while args[i + 2] == options.andKeyword do
if args[i + 3] then
table.insert(forRow.pages, args[i + 3])
end
-- Increment to next "and"
i = i + 2
end
-- Increment to next use
i = i + 2
-- Append the row
table.insert(forTable, forRow)
until terminated or i > maxArg
return forTable
end
-- Stringifies a table as formatted by forSeeArgsToTable
function p.forSeeTableToString (forSeeTable, options)
-- Type-checks and defaults
checkType("forSeeTableToString", 1, forSeeTable, "table", true)
checkType("forSeeTableToString", 2, options, "table", true)
options = options or {}
for k, v in pairs(forSeeDefaultOptions) do
if options[k] == nil then options[k] = v end
end
-- Stringify each for-see item into a list
local strList = {}
if forSeeTable then
for k, v in pairs(forSeeTable) do
local useStr = v.use or options.otherText
local pagesStr =
p.andList(v.pages, true) or
mFormatLink._formatLink{
categorizeMissing = mHatnote.missingTargetCat,
link = mHatnote.disambiguate(options.title)
}
local forSeeStr = string.format(options.forSeeForm, useStr, pagesStr)
forSeeStr = punctuationCollapse(forSeeStr)
table.insert(strList, forSeeStr)
end
end
if options.extratext then table.insert(strList, punctuationCollapse(options.extratext..'.')) end
-- Return the concatenated list
return table.concat(strList, ' ')
end
-- Produces a "For X, see [[Y]]" string from arguments. Expects index gaps
-- but not blank/whitespace values. Ignores named args and args < "from".
function p._forSee (args, from, options)
local forSeeTable = p.forSeeArgsToTable(args, from, options)
return p.forSeeTableToString(forSeeTable, options)
end
-- As _forSee, but uses the frame.
function p.forSee (frame, from, options)
mArguments = require('Module:Arguments')
return p._forSee(mArguments.getArgs(frame), from, options)
end
return p
1c8e6212115f76ecc3db8d05137011cd18207988
Module:Hatnote
828
338
444
443
2025-08-21T16:25:56Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Hatnote --
-- --
-- This module produces hatnote links and links to related articles. It --
-- implements the {{hatnote}} and {{format link}} meta-templates and includes --
-- helper functions for other Lua hatnote modules. --
--------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local checkTypeForNamedArg = libraryUtil.checkTypeForNamedArg
local mArguments -- lazily initialise [[Module:Arguments]]
local yesno -- lazily initialise [[Module:Yesno]]
local formatLink -- lazily initialise [[Module:Format link]] ._formatLink
local p = {}
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
local function getArgs(frame)
-- Fetches the arguments from the parent frame. Whitespace is trimmed and
-- blanks are removed.
mArguments = require('Module:Arguments')
return mArguments.getArgs(frame, {parentOnly = true})
end
local function removeInitialColon(s)
-- Removes the initial colon from a string, if present.
return s:match('^:?(.*)')
end
function p.defaultClasses(inline)
-- Provides the default hatnote classes as a space-separated string; useful
-- for hatnote-manipulation modules like [[Module:Hatnote group]].
return
(inline == 1 and 'hatnote-inline' or 'hatnote') .. ' ' ..
'navigation-not-searchable'
end
function p.disambiguate(page, disambiguator)
-- Formats a page title with a disambiguation parenthetical,
-- i.e. "Example" → "Example (disambiguation)".
checkType('disambiguate', 1, page, 'string')
checkType('disambiguate', 2, disambiguator, 'string', true)
disambiguator = disambiguator or 'disambiguation'
return mw.ustring.format('%s (%s)', page, disambiguator)
end
function p.findNamespaceId(link, removeColon)
-- Finds the namespace id (namespace number) of a link or a pagename. This
-- function will not work if the link is enclosed in double brackets. Colons
-- are trimmed from the start of the link by default. To skip colon
-- trimming, set the removeColon parameter to false.
checkType('findNamespaceId', 1, link, 'string')
checkType('findNamespaceId', 2, removeColon, 'boolean', true)
if removeColon ~= false then
link = removeInitialColon(link)
end
local namespace = link:match('^(.-):')
if namespace then
local nsTable = mw.site.namespaces[namespace]
if nsTable then
return nsTable.id
end
end
return 0
end
function p.makeWikitextError(msg, helpLink, addTrackingCategory, title)
-- Formats an error message to be returned to wikitext. If
-- addTrackingCategory is not false after being returned from
-- [[Module:Yesno]], and if we are not on a talk page, a tracking category
-- is added.
checkType('makeWikitextError', 1, msg, 'string')
checkType('makeWikitextError', 2, helpLink, 'string', true)
yesno = require('Module:Yesno')
title = title or mw.title.getCurrentTitle()
-- Make the help link text.
local helpText
if helpLink then
helpText = ' ([[' .. helpLink .. '|help]])'
else
helpText = ''
end
-- Make the category text.
local category
if not title.isTalkPage -- Don't categorise talk pages
and title.namespace ~= 2 -- Don't categorise userspace
and yesno(addTrackingCategory) ~= false -- Allow opting out
then
category = 'Hatnote templates with errors'
category = mw.ustring.format(
'[[%s:%s]]',
mw.site.namespaces[14].name,
category
)
else
category = ''
end
return mw.ustring.format(
'<strong class="error">Error: %s%s.</strong>%s',
msg,
helpText,
category
)
end
local curNs = mw.title.getCurrentTitle().namespace
p.missingTargetCat =
--Default missing target category, exported for use in related modules
((curNs == 0) or (curNs == 14)) and
'Articles with hatnote templates targeting a nonexistent page' or nil
function p.quote(title)
--Wraps titles in quotation marks. If the title starts/ends with a quotation
--mark, kerns that side as with {{-'}}
local quotationMarks = {
["'"]=true, ['"']=true, ['“']=true, ["‘"]=true, ['”']=true, ["’"]=true
}
local quoteLeft, quoteRight = -- Test if start/end are quotation marks
quotationMarks[string.sub(title, 1, 1)],
quotationMarks[string.sub(title, -1, -1)]
if quoteLeft or quoteRight then
title = mw.html.create("span"):wikitext(title)
end
if quoteLeft then title:css("padding-left", "0.15em") end
if quoteRight then title:css("padding-right", "0.15em") end
return '"' .. tostring(title) .. '"'
end
--------------------------------------------------------------------------------
-- Hatnote
--
-- Produces standard hatnote text. Implements the {{hatnote}} template.
--------------------------------------------------------------------------------
p[''] = function (frame) return p.hatnote(frame:newChild{ title = "Template:Hatnote" }) end
function p.hatnote(frame)
local args = getArgs(frame)
local s = args[1]
if not s then
return p.makeWikitextError(
'no text specified',
'Template:Hatnote#Errors',
args.category
)
end
return p._hatnote(s, {
extraclasses = args.extraclasses,
selfref = args.selfref
})
end
function p._hatnote(s, options)
checkType('_hatnote', 1, s, 'string')
checkType('_hatnote', 2, options, 'table', true)
options = options or {}
local inline = options.inline
local hatnote = mw.html.create(inline == 1 and 'span' or 'div')
local extraclasses
if type(options.extraclasses) == 'string' then
extraclasses = options.extraclasses
end
hatnote
:attr('role', 'note')
:addClass(p.defaultClasses(inline))
:addClass(extraclasses)
:addClass(options.selfref and 'selfref' or nil)
:wikitext(s)
return mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Module:Hatnote/styles.css' }
} .. tostring(hatnote)
end
return p
e4b658e3483374de2bebf772f3d19aaa713ca3f5
Module:About
828
339
446
445
2025-08-21T16:25:56Z
Sharparam
284703
1 revision imported: Imported from Wikipedia
Scribunto
text/plain
local mArguments --initialize lazily
local mHatnote = require('Module:Hatnote')
local mHatList = require('Module:Hatnote list')
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
function p.about (frame)
-- A passthrough that gets args from the frame and all
mArguments = require('Module:Arguments')
args = mArguments.getArgs(frame)
return p._about(args)
end
function p._about (args, options)
-- Produces "about" hatnote.
-- Type checks and defaults
checkType('_about', 1, args, 'table', true)
args = args or {}
checkType('_about', 2, options, 'table', true)
options = options or {}
local defaultOptions = {
aboutForm = 'This %s is about %s. ',
PageType = require('Module:Pagetype').main(),
otherText = nil, --included for complete list
sectionString = 'section'
}
for k, v in pairs(defaultOptions) do
if options[k] == nil then options[k] = v end
end
-- Set initial "about" string
local pageType = (args.section and options.sectionString) or options.PageType
local about = ''
if args[1] then
about = string.format(options.aboutForm, pageType, args[1])
end
--Allow passing through certain options
local fsOptions = {
otherText = options.otherText,
extratext = args.text
}
local hnOptions = {
selfref = args.selfref
}
-- Set for-see list
local forSee = mHatList._forSee(args, 2, fsOptions)
-- Concatenate and return
return mHatnote._hatnote(about .. forSee, hnOptions)
end
return p
1abb25315b25b63b97d98ecae17733cbea8fcc6a
Module:Pagetype/softredirect
828
340
450
2025-08-21T16:31:25Z
Sharparam
284703
Created page with "-- This page contains a table of all soft redirect templates and their -- redirects. Templates names are capitalized, and the Template: prefix is -- removed. Templates are grouped with the main template first, followed by -- its redirects. return { -- ["R from category navigation"] = true, -- ["Redirect from category navigation"] = true, -- ["Category redirect"] = true, -- ["Cat move"] = true, -- ["Cat red"] = true, -- ["Cat redir"] = true, -- ["Cat redirect"] =..."
Scribunto
text/plain
-- This page contains a table of all soft redirect templates and their
-- redirects. Templates names are capitalized, and the Template: prefix is
-- removed. Templates are grouped with the main template first, followed by
-- its redirects.
return {
-- ["R from category navigation"] = true,
-- ["Redirect from category navigation"] = true,
-- ["Category redirect"] = true,
-- ["Cat move"] = true,
-- ["Cat red"] = true,
-- ["Cat redir"] = true,
-- ["Cat redirect"] = true,
-- ["Category move"] = true,
-- ["Category Redirect"] = true,
-- ["Categoryredirect"] = true,
-- ["Catr"] = true,
-- ["Catred"] = true,
-- ["Catredir"] = true,
-- ["Catredirect"] = true,
-- ["R from template-generated category"] = true,
-- ["Redirect from template-generated category"] = true,
-- ["Soft redirect"] = true,
-- ["Interwiki redirect"] = true,
-- ["Plain soft redirect"] = true,
-- ["Soft"] = true,
-- ["Soft link"] = true,
-- ["Soft redir"] = true,
-- ["Soft Redirect"] = true,
-- ["Softr"] = true,
-- ["Softredir"] = true,
-- ["SoftRedirect"] = true,
-- ["Softredirect"] = true,
-- ["Userrename"] = true,
-- ["Wikimedia Commons redirect"] = true,
-- ["COMM"] = true,
-- ["Comm"] = true,
-- ["Commons Redirect"] = true,
-- ["Commons redirect"] = true,
-- ["CommonsRedirect"] = true,
-- ["Commonsredirect"] = true,
-- ["Wikimedia commons redirect"] = true,
}
113c40f4040b1bf259fc2008e16d434acffa11fd
453
450
2025-08-21T16:35:00Z
Sharparam
284703
Sharparam renamed page [[Module:PageType/softredirect]] to [[Module:Pagetype/softredirect]] without leaving a redirect: Misspelled title
Scribunto
text/plain
-- This page contains a table of all soft redirect templates and their
-- redirects. Templates names are capitalized, and the Template: prefix is
-- removed. Templates are grouped with the main template first, followed by
-- its redirects.
return {
-- ["R from category navigation"] = true,
-- ["Redirect from category navigation"] = true,
-- ["Category redirect"] = true,
-- ["Cat move"] = true,
-- ["Cat red"] = true,
-- ["Cat redir"] = true,
-- ["Cat redirect"] = true,
-- ["Category move"] = true,
-- ["Category Redirect"] = true,
-- ["Categoryredirect"] = true,
-- ["Catr"] = true,
-- ["Catred"] = true,
-- ["Catredir"] = true,
-- ["Catredirect"] = true,
-- ["R from template-generated category"] = true,
-- ["Redirect from template-generated category"] = true,
-- ["Soft redirect"] = true,
-- ["Interwiki redirect"] = true,
-- ["Plain soft redirect"] = true,
-- ["Soft"] = true,
-- ["Soft link"] = true,
-- ["Soft redir"] = true,
-- ["Soft Redirect"] = true,
-- ["Softr"] = true,
-- ["Softredir"] = true,
-- ["SoftRedirect"] = true,
-- ["Softredirect"] = true,
-- ["Userrename"] = true,
-- ["Wikimedia Commons redirect"] = true,
-- ["COMM"] = true,
-- ["Comm"] = true,
-- ["Commons Redirect"] = true,
-- ["Commons redirect"] = true,
-- ["CommonsRedirect"] = true,
-- ["Commonsredirect"] = true,
-- ["Wikimedia commons redirect"] = true,
}
113c40f4040b1bf259fc2008e16d434acffa11fd
Module:Pagetype/disambiguation
828
341
452
2025-08-21T16:34:01Z
Sharparam
284703
Created page with "return require [[Module:Disambiguation/templates]]"
Scribunto
text/plain
return require [[Module:Disambiguation/templates]]
9b7267108d8d085f28ae9bed61725ad9e43240c7
Coordinates
0
342
454
2025-08-21T16:47:58Z
Sharparam
284703
Created page with "{{About|the game concept|specifying coordinates in a wiki article|Template:Coordinates}} '''{{PAGENAME}}''' are used to indicate the player's location in the world. == Overview == The player's coordinates consist of three components: the X, Y, and Z coordinate. X and Y denote the position on the horizontal plane, while Z is the vertical position (height). == Bugs == * The coordinates as displayed inside the game on the inventory screen are often incorrect. The game t..."
wikitext
text/x-wiki
{{About|the game concept|specifying coordinates in a wiki article|Template:Coordinates}}
'''{{PAGENAME}}''' are used to indicate the player's location in the world.
== Overview ==
The player's coordinates consist of three components: the X, Y, and Z coordinate. X and Y denote the position on the horizontal plane, while Z is the vertical position (height).
== Bugs ==
* The coordinates as displayed inside the game on the inventory screen are often incorrect. The game truncates each coordinate value to only show the first four digits. As an example, if the player is at X coordinate {{val|13529}} (five digits), the game will show it as {{val|1352}} (four digits). To get an accurate position, usage of software that can enable the Unreal Engine debug HUD is required. If using the Unreal Engine Unlocker software, enable the debug HUD by using the <code>showdebug</code> command.
== External links ==
* [https://dev.epicgames.com/documentation/en-us/unreal-engine/coordinate-system-and-spaces-in-unreal-engine Coordinate System and Spaces] in the Unreal Engine documentation
[[Category:Game mechanics]]
4b2a35e53034534a2fd7a260f1c18bf681e114ed
455
454
2025-08-21T17:06:44Z
Sharparam
284703
Fix numbers temporarily(?)
wikitext
text/x-wiki
{{About|the game concept|specifying coordinates in a wiki article|Template:Coordinates}}
'''{{PAGENAME}}''' are used to indicate the player's location in the world.
== Overview ==
The player's coordinates consist of three components: the X, Y, and Z coordinate. X and Y denote the position on the horizontal plane, while Z is the vertical position (height).
== Bugs ==
* The coordinates as displayed inside the game on the inventory screen are often incorrect. The game truncates each coordinate value to only show the first four digits. As an example, if the player is at X coordinate <!--{{val|13529}}-->13 529 (five digits), the game will show it as <!--{{val|1352}}-->1 352 (four digits). To get an accurate position, usage of software that can enable the Unreal Engine debug HUD is required. If using the Unreal Engine Unlocker software, enable the debug HUD by using the <code>showdebug</code> command.
== External links ==
* [https://dev.epicgames.com/documentation/en-us/unreal-engine/coordinate-system-and-spaces-in-unreal-engine Coordinate System and Spaces] in the Unreal Engine documentation
[[Category:Game mechanics]]
aae05c5dc19ae85bd040d250b6a65c2a649d6e81
Template:Infobox/NPC
10
343
456
2025-08-21T17:21:46Z
Sharparam
284703
Created page with "<includeonly>{{#invoke:Infobox|main | kind = npc | sep=, | image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}} | title = {{{title|{{PAGENAME}}}}} }}{{#if:{{NAMESPACE}}||[[Category:NPCs]]}}</includeonly><noinclude> {{Documentation}} </noinclude>"
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind = npc
| sep=,
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| title = {{{title|{{PAGENAME}}}}}
}}{{#if:{{NAMESPACE}}||[[Category:NPCs]]}}</includeonly><noinclude>
{{Documentation}}
</noinclude>
02c1a8c11cfad8392626d8b5b51c89305185a1e9
Template:Infobox/NPC/doc
10
344
457
2025-08-21T17:24:18Z
Sharparam
284703
Created page with "== Example == {{Infobox/NPC | title = The Handler | image = The Handler.png }} <syntaxhighlight lang="wikitext"> {{Infobox/NPC | title = The Handler | image = The Handler.png }} </syntaxhighlight> <includeonly>{{Sandbox other|| [[Category:Infobox templates]] }}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== Example ==
{{Infobox/NPC
| title = The Handler
| image = The Handler.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/NPC
| title = The Handler
| image = The Handler.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||
[[Category:Infobox templates]]
}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
d6d4e015f0c8254a14cabf15ee3f9625d87804ac
The Handler
0
345
458
2025-08-21T17:26:20Z
Sharparam
284703
Created page with "{{Infobox/NPC | image = The Handler Blok 6147.png }} '''{{PAGENAME}}''' is an [[NPC]] in {{BFF}} that will let the player upgrade their [[equipment]], embed crystals into it, and manufacture certain [[items]]. == Overview == Other than serving as a way to upgrade and manufacture items, she will also give the player some guidance on their next objective. She will usually appear next to the [[Homunculus]] closest to the entrance of an area. The Handler's synchronizati..."
wikitext
text/x-wiki
{{Infobox/NPC
| image = The Handler Blok 6147.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}} that will let the player upgrade their [[equipment]], embed crystals into it, and manufacture certain [[items]].
== Overview ==
Other than serving as a way to upgrade and manufacture items, she will also give the player some guidance on their next objective.
She will usually appear next to the [[Homunculus]] closest to the entrance of an area.
The Handler's synchronization level can be increased by finding [[Handler Echo|handler echoes]] and bringing them to her. Increasing her level allows for upgrading [[equipment]] to higher levels.
== Appearance ==
She appears to be some sort of robot or cyborg, with light skin, black parts, and silver hair.
== Locations ==
{| class="wikitable"
! scope="col" | Area
! scope="col" | Description
! scope="col" | Coordinates
|-
| [[Monastery]] || Near the first [[Homunculus]] (only in [[New Game Plus]]) || {{coords|23473.78|-85243.22|-15260.61}}
|-
| [[Blok 6147]] || In the center (right next to the [[Homunculus]]) || {{coords|-25.27|442.48|1160.96}}
|-
| [[Deluge]] || Sitting on a ledge near the first [[Homunculus]] || {{coords|-3307|-7449|5650}}
|-
| [[Asylum]] || Standing in front of a pillar near the [[Homunculus]] || {{coords|-4507|6967|9032}}
|-
| [[Upper Blocks]] || Standing in front of some rubble opposite of the [[Homunculus]] || {{coords|4585|1626|2193}}
|-
| [[Machinarium]] || Standing next to a wall just past the first [[Homunculus]] || {{coords|-2125.53|27029.25|-12156.72}}
|-
| [[Desert]] || Standing next to a wall just past the [[Homunculus]] || {{coords|-9576.35|65589.26|-136382.62}}
|-
| [[Anomaly]] || Standing next to a pair of pillars just past the [[Homunculus]] || {{coords|46782.80|162169.12|-141987.55}}
|-
| [[Vermillion Fields]] || Standing next to the [[Homunculus]], mirroring her location in [[Blok 6147]] || {{coords|582|-4995|1178}}
|}
== Quotes ==
=== When approached ===
When approached without any special event dialogue waiting to be triggered, she will pick one of the below greeting phrases at random.
{{Quote|Hello!|audio=The_Handler_Hello.ogg}}
{{Quote|Hello there!|audio=The_Handler_Hello_There.ogg}}
{{Quote|Well hello there!|audio=The_Handler_Well_Hello_There.ogg}}
{{Quote|Back so soon!|audio=The_Handler_Back_So_Soon.ogg}}
{{Quote|Look who came to visit!|audio=The_Handler_Look_Who_Came_To_Visit.ogg}}
=== First encounter ===
{{Quote
|You're finally here. We can now commence the [[recalibration]].
I've updated the locations of the malfunctioning modules in the terminal. Any time you link to a terminal, you should be able to see the modules.
I must advise utmost caution, as I have surveyed the area and it is infested with aggressive mutations.
The radiation leaking out of [[The Anomaly|the anomaly]] is causing a strong disturbance in the casual field. We should leave this place as soon as possible.
The readings are unlike anything I've seen. The data is completely unstable as I am still unable to upload it for decyphering.
Farewell.
| audio = The_Handler_First_Encounter.ogg
}}
=== After first [[recalibration]] ===
{{Quote
|There is one module left to recalibrate. Unfortunately the data leaking from [[The Anomaly|the anomaly]] is still too corrupted to read.
The surveillance net has taken note of ripples with particularly long wavelengths unusually coming into existence. I believe it's a sign of intruders – particularly dangerous ones that are not of our timeline.
I am not sure I understand what exactly is going on here. I suppose we are yet to learn the true definition of something anomalous.
Farewell.
}}
=== After second [[recalibration]] ===
{{Quote
|The [[recalibration]] was successful, the transgression field is down.
[[The Anomaly|The anomaly]] is now exposed and ready to be stabilized.
''*silence*''
I'm afraid I will be breaching protocol by telling you, that since the recalibration – I have been unable to transmit or receive any transmissions from any other floor.
If I had to make a guess, I would say something from inside the anomaly is tampering with much more than just the causal field. I am afraid I am not equipped to run a robust field analysis, but I speculate we're dealing with an event far outside our scope.
Nevertheless, I did run some more rudimentary data decrypting processes.
The leaks from inside the anomaly are not arbitrary, they reveal the patterns of language. I have tried to compute at least the general scope and nature of its form – but the permutations are overwhelming all of my systems.
Simply running the processes has had some kind of spillover effect into the computing instruments themselves. This language is of unfathomable complexity.
Take great caution, these are circumstances far outside the realms of understanding.
Farewell.
}}
=== First encounter in [[Vermillion Fields]] ===
{{Quote
|Good to see a familiar face.
I must admit, I am no more aware of what is really taking place than I was before this turn of events. I believe there is a powerful external force moving the needle here, and we are completely oblivious to its nature.
I am afraid I won't be of much more use to you in this state, and I'm not quite sure how I've even made it this far. However, I will help with what I can, while I'm here.
I did however learn something. While being transported I noticed a certain Vermillion branching structure buffering this entire world and its roots run deeply. My access was promptly restricted, leaving me in this condition.
Whatever effect the Vermillion structure has, we must be very careful. I believe it has access to base reality, in which case we are dealing with a potential cataclysmic event.
I don't know if it is fear, or excitement – whatever we are experiencing here makes me feel in a way I find hard to describe.
Stay safe.
}}
Her lines in [[Vermillion Fields]] are delivered in a distorted voice, she will also no longer greet the player when approached. Despite her claims about not being of much use any more, she can still perform all of her normal functions.
== Gallery ==
<gallery>
File:The_Handler_Blok_6147.png|[[The Handler]] in [[Blok 6147]].|alt=Screenshot showing The Handler standing around in Blok 6147.
File:The_Handler_Deluge.png|[[The Handler]] in [[Deluge]].|alt=Screenshot showing The Handler sitting on a ledge in Deluge.
File:The_Handler_Asylum.png|[[The Handler]] in [[Asylum]].|alt=Screenshot showing The Handler standing around in Asylum.
File:The_Handler_Upper_Blocks.png|[[The Handler]] in [[Upper Blocks]].|alt=Screenshot showing The Handler standing around in Upper Blocks.
File:The_Handler_Machinarium.png|[[The Handler]] in [[Machinarium]].|alt=Screenshot showing The Handler standing around in Machinarium.
</gallery>
== Trivia ==
* The game files call her "Blacksmith".
{{Navbox/NPCs}}
02c4e3851b0e4e388eeab0d2e668595e202d0df7
Template:BFF
10
346
459
2025-08-21T17:27:27Z
Sharparam
284703
Created page with "''[[Bleak Faith: Forsaken]]''"
wikitext
text/x-wiki
''[[Bleak Faith: Forsaken]]''
a07fd38648935c2ecd381aa47db3694dae3fb873
Handler
0
347
460
2025-08-21T17:27:58Z
Sharparam
284703
Redirected page to [[The Handler]]
wikitext
text/x-wiki
#REDIRECT [[The Handler]]
88b800514a0b691d707ee19ba584e637d3655f46
Category:NPCs
14
348
461
2025-08-21T17:28:32Z
Sharparam
284703
Created page with "Non-player characters (NPCs) in {{BFF}}."
wikitext
text/x-wiki
Non-player characters (NPCs) in {{BFF}}.
0dc1d8049d1a57e3aac84eafca49335d4d35f2d8
Category:Pages with inaccurate coordinates
14
349
462
2025-08-21T17:29:20Z
Sharparam
284703
Created page with "Contains pages using the {{tl|Coordinates}} template or {{ml|Coordinates}} module but passing in one or more coordinates that can be verified to not be completely accurate (i.e. coordinates with fewer than 2 decimals)."
wikitext
text/x-wiki
Contains pages using the {{tl|Coordinates}} template or {{ml|Coordinates}} module but passing in one or more coordinates that can be verified to not be completely accurate (i.e. coordinates with fewer than 2 decimals).
123078e1af276f585a511310432b32907710954a
Category:Pages with coordinates
14
350
463
2025-08-21T17:30:55Z
Sharparam
284703
Created page with "Contains pages that use the {{tl|Coordinates}} template or {{ml|Coordinates}} module."
wikitext
text/x-wiki
Contains pages that use the {{tl|Coordinates}} template or {{ml|Coordinates}} module.
5d1e1be9b3942073a809cd311bdcb1f00bb23507
Locations
0
351
465
464
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox/Locations}}
980e15253d6e4f1418e9efa737c209de74f57252
Uranopolis
0
352
467
466
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''Uranopolis''' is a location in {{BFF}}.
== Sub-locations ==
Uranopolis consists of two sub-locations: Tower Complex and {{TODO}}.
=== Tower Complex ===
{{Main|Uranopolis/Tower Complex}}
[[File:Uranopolis (Tower Complex).png|thumb|The tower complex as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Tower Complex area.]]
The '''Tower Complex''' is the first sub-location encountered by the player.
{{clear}}
=== Lone Tower ===
[[File:Uranopolis (Lone Tower).png|thumb|The lone tower as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Lone Tower area. The towers housing the area's boss as well as the recalibration "eye" can be seen.]]
The '''Lone Tower''' is the second sub-location encountered by the player. The area's boss – [[Nurgei the Blademaster]] – can be found here.
{{Navbox/Locations}}
[[Category:Locations]]
fc3e22f798adfdd04bd6befa151ccc23aa80ecd5
Blok 6147
0
353
469
468
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Blok 6147.png|thumb|Blok 6147 as depicted in the game's relocation menu.|alt=Artwork showing the central area in Blok 6147.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A vast ringed and radial expanse of intricate concrete architecture, adorned with grand archways, ornate carvings, and timeworn {{sic|hide=y|expected=time-worn}} structures that narrate centuries of rich history.
}}
== Trivia ==
* If the game is saved while in Blok 6147, the location listed on the save file will be "Blok 6174". This is presumably a typo as the location is referred to as Blok 6147 in both the pause menu and [[Homunculus]] relocation list.
{{Navbox/Locations}}
[[Category:Locations]]
bda6e533357582f201b31b2a208855d0bdc73471
Monastery
0
354
471
470
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Lower ==
[[File:Monastery (Lower).png|thumb|The lower monastery as depicted in the game's relocation menu.|alt=Artwork showing the long bridge in the lower Monastery where the player starts.]]
{{Quote
| A rusted, skeletal bridge precariously connects two towering structures high above a chaotic maze of crumbling buildings
}}
{{clear}}
== Upper ==
[[File:Monastery (Upper).png|thumb|The upper monastery as depicted in the game's relocation menu.|alt=Artwork showing a scene from the upper monastery. The actual monastery building where the area's boss is can be seen in the background.]]
{{Quote
| Perched atop a jagged cliff, the ancient monastery, with its weathered stone walls and moss-covered spires. Serene isolation amidst the surrounding chaos.
}}
{{Navbox/Locations}}
[[Category:Locations]]
c45661f5fc6c65355deb9f8c90263eb72574a274
Rain District
0
355
473
472
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Sewers ==
[[File:Rain District (Sewers).png|thumb|The rain district sewers as depicted in the game's relocation menu.|alt=Artwork showing the sewers in the rain district.]]
{{Quote
| A maze of flooded tunnels with murky water that echoes the constant patter of rain from above, walls slick with moss and grime, and a stench of decay that ingles with the distant roar of rushing water and the occasional scurrying of unseen creatures.
}}
{{clear}}
== Center ==
[[File:Rain District (Center).png|thumb|The rain district center as depicted in the game's relocation menu.|alt=Artwork showing the center room in the rain district.]]
{{Quote
| A residential area lying in perpetual rain. Its dilapidated buildings stand silent and forlorn, windows shattered, rooftops caved in, walls rotting with mold. The relentless downpour
}}
{{Navbox/Locations}}
[[Category:Locations]]
411486cc02e286f1982f8922cb1e84ebe86d13e4
Deluge
0
356
475
474
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Deluge.png|thumb|Deluge as depicted in the game's relocation menu.|alt=Artwork showing the Deluge area filled with water with structures lining the sides.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| A vast reservoir stretches out like a somber mirror, its surface eerily still, broken only by the faintest ripples. Shadowy shapes drift beneath the dark water, their forms indistinct and haunting.
}}
{{Navbox/Locations}}
[[Category:Locations]]
693a79d49e7efc3474fef04a49a6ecfcf873ac1f
Asylum
0
357
477
476
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls.
}}
{{Navbox/Locations}}
[[Category:Locations]]
37e0b512f0b81e8f301b3b2858e9d4da7562c26f
Upper Blocks
0
358
479
478
2025-08-21T17:34:28Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Upper Blocks.png|thumb|Upper Blocks as depicted in the game's relocation menu.|alt=Artwork showing the tall buildings that make up the upper blocks.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| The abandoned residential and industrial sector is silent, with decaying buildings and rusting machinery shrouded in a heavy layer of dust and cobwebs. Overgrown vines and weeds cling to the crumbling facades, while the occasional gust of wind stirs the remnants of a once-bustling area, now frozen in time and isolation.
}}
{{Navbox/Locations}}
[[Category:Locations]]
8eb05dbbf1b2eca301ec7824369953ecf59627e8
Ghost Town
0
359
481
480
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Floor 13 ==
[[File:Ghost Town (Floor 13).png|thumb|The 13th floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing a view down a tall shaft in Ghost Town, stairs lining the walls.]]
{{Quote
| Crumbling, dilapidated buildings shrouded in mist. Faded, peeling paint reveals dark stains on the decaying facades – the area is haunted by the whispers of its forgotten past.
}}
{{clear}}
== Floor 1 ==
[[File:Ghost Town (Floor 1).png|thumb|The 1st floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing an outside scene in Ghost Town depicting several high-rise residential buildings.]]
{{Quote
| A decrepit graveyard sprawls with uneven, weather-beaten tombstones. Sunken graves, choked with tangled weeds. Rusted tracks stretch out into the darkness, and the empty ticket counters and derelict waiting rooms are cloaked in fog.
}}
{{Navbox/Locations}}
[[Category:Locations]]
de022882ea75493bf878521b5de2b72ab78ee421
Machinarium
0
360
483
482
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Machinarium.png|thumb|Machinarium as depicted in the game's relocation menu.|alt=Artwork showing an area in the Machinarium: A short walkway leading to a small building. In the background can be seen taller structures with bridges between them.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Rusted machinery and oil-slicked floors are interspersed with tarnished religious relics, like ancient statues and faded icons, which add a somber contrast yet subtly complement the mechanical decay.
}}
{{Navbox/Locations}}
[[Category:Locations]]
bdce97e055f63d9b564bb8af98884bb9353ec5db
Desert
0
361
485
484
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Desert.png|thumb|Desert as depicted in the game's relocation menu.|alt=Artwork showing the large palace in the desert. The labyrinth can be seen in the background.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A dark desert stretches endlessly at the foot of the towering city. Harsh winds whip through the desolate landscape, sending wisps of sand swirling around skeletal remains of old structures. The oppressive silence is occasionally broken by the distant echo of the city's hum.
}}
{{Navbox/Locations}}
[[Category:Locations]]
7a4e1dcb94c588a7cbdfa9c4abb1a9303a8d2d79
Desert Mirage
0
362
487
486
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Desert Mirage.png|thumb|Desert Mirage as depicted in the game's relocation menu.|alt=Artwork showing the desert mirage. The entrance building can be seen on the left, with several towers in the background.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A desert from another time.
}}
{{Navbox/Locations}}
[[Category:Locations]]
b77e5799a2dcb88ca21171824a322e70e1ceed2f
Anomaly (location)
0
363
489
488
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]]
The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still.
}}
{{Navbox/Locations}}
[[Category:Locations]]
a8fc6f2bc209173c6c2c5d3d178232dfb1ed8321
Vermillion Fields
0
364
491
490
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
Upon reaching '''Vermillion Fields''', all previous [[locations]] become inaccessible and are no longer shown in the relocation menu of the [[Homunculus|homunculi]].
== Plaza ==
[[File:Vermillion Fields (Plaza).png|thumb|The Vermillion Fields plaza as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields plaza, an outdoors scene with red foliage and the circular center structure seen on the left.]]
{{Quote
|Forms standing out sharply against the striking vermillion landscape. A sea of fiery hues stretch endlessly. A familiar structure looms over the field.
}}
{{clear}}
== Temple ==
[[File:Vermillion Fields (Temple).png|thumb|The Vermillion Fields temple as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields temple.]]
{{Quote
|Perched atop the [[Vermillion Fields|vermillion fields]], the monastery rises as a monolithic, stunning structure with grand, sweeping arches and intricate carvings. Its imposing presence is both serene and majestic, standing out against the vibrant landscape with a timeless, ethereal beauty. A poetry in shapes.
}}
{{Navbox/Locations}}
[[Category:Locations]]
71f1f17927909020242b8cf472a7e2f89199d643
Unknown (location)
0
365
493
492
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{About|the [[Locations|location]]|the [[Bosses|boss]]|Unknown (boss)}}
'''Unknown''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
As the Unknown cannot be relocated to, it has no artwork image and no in-game description.
{{Navbox/Locations}}
[[Category:Locations]]
351676f2dfc783d43a014b11a690031ea946e2b8
Unknown
0
366
495
494
2025-08-21T17:34:29Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''Unknown''' may refer to:
== Common meanings ==
* [[Unknown (location)]], the location with the platforming puzzles leading to an optional boss.
* [[Unknown (boss)]], the boss enemy that can be optionally fought in the location sharing its name.
{{Disambiguation}}
a972049d778c73207104b07ad235871c7a53466d
NPC
0
367
497
496
2025-08-21T17:35:52Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[NPCs]]
0c78678b45694b9a9f67883eca2a30eaa6ea5607
NPCs
0
368
499
498
2025-08-21T17:35:52Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''Non-player characters (NPC)''' are characters in {{BFF}} that can aid the player, provide services, or be spoken to in order to learn more about the world.
== Notable NPCs ==
* [[The Handler]] – Upgrades [[equipment]] and allows for [[crafting]] certain [[items]].
{{Navbox/NPCs}}
79553771fc8e6ca775b99979d35e2de32ae39cbb
Untitled Log
0
369
501
500
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[lore]] [[Documents|document]] that can be found in {{BFF}}.
== Overview ==
There are multiple untitled logs in the game, each with their own text.
{{Quote
|I remember waking in a pile of lifeless bodies. Not only lifeless though. Expressionless. Frozen visages.
}}
{{Quote
| Like waking from a dream about dreaming, everything is a haze. A dark ominous haze. I've seen death, pain, and torture. I hear a voice. Once in a while I see the voice beckon, like a ripple in water – before I can make form of the image. I am gone too.
}}
{{Quote
| I have no mouth, and I know nobody would hear me scream.{{note|Likely a reference to [[wikipedia:I Have No Mouth, and I Must Scream|I Have No Mouth, and I Must Scream]].}}
}}
{{Quote
| No matter where my mind wanders, there is an oppressive red mist crushing the reaches of my imagination. Try as I might, there seems to be no escape. No escape. Only a journey deeper. Farther.. but what awaits at the innermost depths. I suppose the [[Omnistructure]] makes room beyond sense.. beyond time.
}}
== Notes ==
{{notelist}}
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
472bf3de6dbca52f57c3f288b12ad3650a51f3b6
Monastery Impression
0
370
503
502
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] that can be found at [[Monastery|the Monastery]] in {{BFF}}.
== Overview ==
{{Quote
| Venturing into the anomalous zone at the edge of this crumbling colony, I was enveloped by a world devoid of sense, dominated by the cold, relentless sprawl of concrete and rebar. Rusted metal carcasses of buildings stood as grim monuments to a forgotten era, their skeletal frames interwoven with the vestiges of ancient technology and tangled cables that snaked across the ground like decaying veins. The omnipresent drone of [[Omnistructure|the structure]] reverberated through the air, a constant reminder of its oppressive presence – here, louder than anywhere before. As I picked my way through the debris, I could sense the weight of the past pressing in, the technological remnants whispering secrets of a world that once thrived but now lay silent and corroded.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
5d6199c92d0ebf1baedb5890d3776274eadefaef
Lore
0
371
505
504
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' can be found as text on [[items]], various [[data logs]] and [[documents]], and [[NPC]] dialogue in {{BFF}}.
== Data logs ==
{{Main|Data logs}}
== Documents ==
{{Main|Documents}}
{{Navbox/Lore}}
[[Category:Lore]]
3efab73936854b174032435bb0c6f8b77736139d
Data logs
0
372
507
506
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[items]] that can be found in the world of {{BFF}}.
== Overview ==
Data logs are uncovered by interacting at certain specific points in the game world. To locate these points, use of the [[Scanner]] is recommended.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
0b268f9f4958f98eba1f00ec6c06edbba3c10826
Documents
0
373
509
508
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[items]] that can be found in the world of {{BFF}}.
== Overview ==
Documents are typically found as drops from [[enemies]].
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
3305c6ccf580021e8513f612ab7919e6863f1f47
Scanner
0
374
511
510
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| image = Scanner.png
| title = {{PAGENAME}}
| Description = Captures and interprets data across hidden and abstract dimensions, revealing information that transcends conventional spatial and temporal limits, providing a comprehensive view of both visible and imperceptible phenomena.
}}
The '''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Overview ==
Activating the item scans the area around the player, revealing important interactables like [[data logs]] and ladders.
{{Navbox/Items}}
[[Category:Essential items]]
[[Category:Lore]]
72e26e842e217333080947ca9fd96dff00b2be1e
Dust Sea
0
375
513
512
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
| At the base of the sprawling mining facility, a deep mist blankets the ground, leading out to a vast, desolate desert. This desert's sand is a choking mix of dust and residue from the countless constructions and creations towering above. The air is perilous to breathe, laden with fine particles that can invade the lungs. Scattered across this wasteland are the carcasses of long-forgotten machinery and the ruins of old structures. The architecture of these relics hints at a bygone era, a dark age marked by more primitive technology. This eerie landscape tells a silent tale of a past civilization, now buried beneath the relentless sands of time.
}}
== Location ==
{{coords|-4062|-2272|5797}}
Can be found at the top of a broken down tower in [[Deluge|the Deluge]] area, just past the [[Folk Cape]]. After reaching the first [[homunculus]] of the area, walk up the stairs (past [[The Handler]]) and head left. Continue forward until reaching the big tower, climb it to the top and you will find the data log at the edge of the tower (use [[Scanner|the Scanner]] to see it more easily).
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
90fdcaf4874fbb945c79bf4bf3df130f8ba25db5
Psychosis
0
376
515
514
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}.
== Overview ==
{{Quote
|I've repeated the Completeness Protocol over 40 times now to no avail. No training can prepare a mind for this. All sense and reason are gone. The mental fortitude required to hold a coherent thought for longer than a heartbeat is soul-crushing. It feels like I am existing from one moment to the next. Picking up the remnants of déjà vu after déjà vu…
}}
== Location ==
{{coords|-5130|-1039|5616}}
Found in [[Deluge|the Deluge]] area, near one of the [[Upgrade Splinter|upgrade splinters]] in the first big rectangular structure with pillars, near the first red lightpole. Use [[Scanner|the Scanner]] to more easily find the data log.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
b4998452a6a35bf04aeb60ea5d8c95c3edf9e497
Night Horror
0
377
517
516
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] that can be found in {{BFF}}.
== Overview ==
{{Quote
|In the tower of [[Asylum|the asylum]], a chilling and unearthly wail reverbates through the walls—a sound that can only be described as the cry of a banshee. The eerie, mournful shrieks cut through the silence, hinting at a presence both agonizing and spectral. Among the abominations and horrors that define this place, one patient remains, but it's difficult to truly say they have survived. This lone individual, if they can still be called such, exists in a state that blurs the line between life and death, their being a twisted echo of humanity amidst the torment. The banshee's cries seem to emanate from this tormented soul, a haunting reminder of the asylum's dark legacy and the incomprehensible suffering endured within its dark halls.
}}
== Location ==
{{coords|-3811|1199|9172}}
Found in [[Asylum|the Asylum]]. Located below a staircase after leaving the first building. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
fc7ee13e9ef0e02cd4a7722f0e91cb2e83028519
The Banshee
0
378
519
518
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] that can be found in {{BFF}}.
== Overview ==
{{Quote
| The banshee's movements, dancing through [[Asylum|the asylum's]] decaying tower, are unsettingly precise, as if they were once part of a carefully honed combat style. Each anguished gesture and frenzied motion mirrors advanced fighting techniques, reminiscent of those taught at the highest levels of military training. The eerie choreography suggests that the creature's wails are not merely cries of torment, but the remnants of a brutal experiment aimed at forging a living weapon. The movements, though now distorted and ghostly, hint at a once-formed discipline, twisted into a nightmarish mockery of the intended martial prowess. This spectral entity seems to embody the cruel ambition of those who sought to create a perfect instrument of war through unthinkable means.
}}
== Location ==
{{coords|-3943|1596|1532}}
Found in the center of a circular room, surrounded by chairs, in the big tower in [[Asylum|the asylum]]. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
0309dfabb2c1cb6950f037a68ebce98a2b67b20f
Hellicar's Maxims
0
379
521
520
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[documents]] that can be found in {{BFF}}.
== Acquisition ==
Drops from [[enemies]] in the game.
* Asylum enemy with cape and sword+shield.
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
9e54fe19f15f8d8dce8dd560ec5bc7a0f7a98dab
Shadows in the Courtyard
0
380
523
522
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
| There's a radial pattern in [[Blok 6147|this Blok]]. A heavily pedestrian zone. The people living here must have had a rather communal spirit. I can't tell if it's just my mind, but I can hear the echoes of children shouting. The ring of a school bell. The creek of a rusty gate opening and closing in a morning ritual. I imagine some of the views here are rather stunning.
}}
== Location ==
{{coords|-1016|-3857|2319}}
Found in [[Blok 6147]], on a round balcony overlooking the central hub.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
3ea9546e3cf140db20981b41b9f9f6e2f674c210
Inhabitants
0
381
525
524
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{stub}}
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}.
== Overview ==
{{Quote
|The inhabitants, if they can be called that, move through their days in a trance-like manner, their actions governed by the city's oppressive rhythm rather than any discernible purpose. They drift through the shadowy streets, their forms often indistinguishable from the pervasive gloom that surrounds them. Their movements are slow and deliberate, almost mechanical, as if each step is taken in reluctant compliance with an unseen force.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
1fac3c562d846adb7b3b2e5ab3eb4d386c14b532
Serpentine Visions
0
382
527
526
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Among the towering spires of the city, there are whispers of a colossal sky serpent that drifts silently through the steel and concrete canyons. Though the serpent is said to be harmless, its sheer size and graceful, serpentine movements evoke both awe and trepidation. With scales that shimmer in hues matching the city's metallic sheen, the serpent weaves effortlessly through the narrow gaps between the tower, its long, undulating body casting an imposing shadow over the pristine surfaces below. its presence, though non-threatening, is a constant reminder of the vastness and wildness that still lingers even in this meticulously engineered urban landscape. The serpent's slow, deliberate light adds a touch of majesty and enigma to the stark cityscape, making its silent passage through the towering structures a mesmerizing spectacle that commands both reverence and respect.
}}
== Location ==
{{coords|9922|-6769|1440}}
Found in [[Uranopolis]] on a ledge on one of the platforms reached by navigating the bridges. Use [[Scanner|the scanner]] to find it more easily.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
e002a14503e5a3d60e77f6a2a8484fc1381a05d3
Shifting Sands
0
383
529
528
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|There are unsettling rumors about a colossal worm with wings made of bones, said to inhabit a hidden realm. This serpentine creature is described as having a face that resembles a person frozen in a dream, an eerie visage that defies understanding. The worm is said to speak and whisper to anyone who dares enter its domain—or even to those who merely think about it. Its nature alludes to something of maker origin. Something capable of changing the structure.
}}
== Location ==
{{coords|-9400|7378|-1350}}
Found in [[Desert|the Desert]], near the big enemy with red eyes after crossing the bridge past the [[Homunculus]]. It is in front of a set of doors.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
b48a873694f25c03f22938908578b61c6b9c4912
Call of the Void
0
384
531
530
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|The giant staircase looms before me, its sheer expanse a vertiginous marvel that seems to stretch endlessly downward into the void. Each step is a monstrous slab of cold, unfeeling metal, worn smooth by countless unknown feet. As I descend, the sense of vertigo intensifies, and the emptiness below grows ever more profound. The abyss at the base of the staircase seems to call out with an irresistible allure, a dark, seductive whisper that tugs at the edges of my mind. The staircase feels alive with this haunting invitation, a siren song of emptiness that beckons irresistibly into the darkness below.
}}
== Location ==
{{coords|1132|-8482|1965}}
Found in [[Ghost Town#Floor 13|Ghost Town (Floor 13)]]. Starting from the [[Homunculus]], head down the stairs. Head up the stairs behind the crying enemy at the bottom and the data log will be at the end of the walkway. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
6926f68eafdb547e25880491f97dcb505ad73b95
Umbral City
0
385
533
532
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|I stumbled through the mist-shrouded sector of the city, disoriented and weary, an unsettling chill gripped me. The residential area ahead was cloaked in an eerie, ghastly haze. Every step felt heavier, as if the very air was laden with the weight of forgotten despair. I descended further into the sector, my path leading me to a graveyard that lay at the bottom, shrouded in the same pervasive mist. The gravestones, ancient and crumbling, stood like mournful sentinels in the ghostly fog. I could feel a strange, unsettling energy emanating from the ground, a spectral force that seemed to pulse through the halls around me. The sorrow and loss from the graveyard seeped into the very walls of this place, wrapping me in a shroud of grief. The haunting resonance of the graveyard's energy made every breath feel heavy, and the oppressive atmosphere left me with an unshakable sense of inescapable sorrow, as if the very essence of this forsaken place was reaching out to ensnare me.
}}
== Location ==
{{coords|1109|-9166|-1494}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], go through the doorway and take the right path, going down the stairs and following the corridors until you arrive at the subway. Go to the right and get to the end to find the data log in the corner. Use [[Scanner|the scanner]] to more easily find it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
f48b4c78d4059ac73cd01b56ac5efdc5e95bd143
Intercepted Transmission
0
386
535
534
2025-08-21T17:38:33Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|You won't get to see the fruits of your sacrifice, and only you will ever know the pain of your solitude. I'm sorry. I'll never forget you.
}}
== Location ==
{{coords|1908|-1765|-806}}
In [[Blok 6147]]. After exiting the [[subway]], take that path that leads up and then walk down the stairs to find the data log in a corner. Use [[Scanner|the scanner]] to find it more easily.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
f7a214fac38ad015fc367e76f78b3c313073255d
Desert Dream
0
387
537
536
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|According to the readings, this gateway offers a glimpse into a reality untouched by the distortions and chaos of [[The Anomaly|the anomaly]], a place where time and space unfolded in a different manner, free from the relentless upheaval that defines this place. The sand serpent's presence must be related.
}}
== Location ==
{{coords|1471|6344|-1395}}
Found in the [[Desert]]. It's located in front of the teleportation orb that leads to [[Desert Mirage]].
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
fb7777879af3c3d248160f4349e8cabe96b0e304
Heartbeat
0
388
539
538
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Have you ever tried to paint a loved one's face from memory? The image shifts and deforms, highlighting the mind's fleeting nature. Drawing from memory is an abstract skill, breathing and heartbeats are automatic. Now, even these feel abstract to me. I have to consciously breathe and encourage my heart to beat, doubting its rhythm if I can't feel it. My heartbeat feels like as word repeated until it loses meaning. Nothing endures here.
}}
== Location ==
{{coords|3326|-6471|-6573}}
Found in the [[Monastery#Lower|Monastery (Lower)]]. Starting at the [[Homunculus]], go forward until the end of the roof where the first enemy is, then take the left path that goes down several stairs. Continue into the hallway at the bottom and take a left, then go up the elevator. Go straight and you'll come to a platform with a staircase going up to the right. The data log is right before the staircase. Use [[Scanner|the scanner]] to more easily find it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data log]]
e6a4f885a6f4e9bd91ce07da3168957b45e7a308
Silent Streets
0
389
541
540
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Interaction between the city's inhabitants is minimal and strangely formal. They pass one another with vacant, almost resigned nods, their conversations reduced to whispers that blend seamlessly with the ambient hum of the city. The air is filled with a sense of inevitability, as if their routines are an attempt to impose a semblance of order on an environment that has long forsaken any true sense of purpose or coherence. In this dreamlike, consuming city, their lives are a reflection of the city's own tragic state—a relentless cycle of existence without progress, forever trapped in the shadow of their own lost potential.
}}
== Location ==
{{coords|1244|1057|1956}}
Found in [[Blok 6147]]. In an alley with a fire and nearby cargo box. It's in the area with multiple walkways at different heights with stairs between.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
d244a7077b0a0b4ba8290bdd23f999bdbf664d08
Statues
0
390
543
542
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Often found in the narrow corridors and shadowy alcoves of the city, their bodies rigidly aligned as if caught in a perpetual moment of exhaustion. Some are positioned near the vast concrete walls, their outlines faintly illuminated by the dim, ambient light, creating haunting silhouettes against the cold surface. Their eyes vacant, reflecting the dim glow of the city in a fixed, lifeless gaze.
}}
== Location ==
{{coords|1424|1365|3124}}
Located in [[Blok 6147]] at the end of one of the walkways with stairs between them.
[[File:Statues_location.jpg|thumb|left|Location of the data log.|alt=Screenshot showing the location of the data log.]]
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
afc40155102345cb921361ea566916b295ded7c5
Unknown Limits
0
391
545
544
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|From within, the boundary of the anomaly seems both infinite and elusive, with no clear beginning or end. It sprawls outwards in a chaotic, unpredictable manner, its influence warping space and time to create a disorienting and treacherous landscape. The sphere's growth is not linear but irregular, expanding and contracting as it incorporates elements from its surroundings, twisting them into bizarre, unrecognizable forms.
}}
== Location ==
{{coords|4984|1575|-1420}}
Found in the [[Anomaly]]. When entering the area, it is the first thing you will come across as the cave opens up to the outdoors area. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
9c79704fa399a5c94c900c27d6cb8c39b760f58a
The Grave Predicament
0
392
547
546
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|The Administration, a dominant force within this tangled system, exhibits a deeper grasp of [[Omnistructure|the Omnistructure's]] workings compared to other entities. However, its own nature is so enigmatic that it seems to be more an emergent symptom of [[Omnistructure|the Omnistructure]] than a genuine part of it. The Administration's methods and motivations are as elusive as [[Omnistructure|the Omnistructure]] itself, blending seamlessly into the very fabric of the mysterious domain it governs within it. Its presence, while influential, only adds to the overall complexity of [[Omnistructure|the Omnistructure]], reinforcing the idea that understanding this colossal construct may forever remain an elusive, if not an impossible, pursuit. Nevertheless we must try. Our very survival hinges on our ability to adapt, and without understanding at the very least our immediate surroundings in this labyrinth, we have no room to elude the ever-pursuing peril that surrounds us.
}}
== Location ==
{{coords|4404|1793|-1412}}
Located on an edge overlooking the labyrinth in the [[Anomaly]] area, just after [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius']] boss arena. Use [[Scanner|the scanner]] to more easily locate it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
4a149e96e2d9c362546ae535afb986f4d6e1cb03
Kaleidoscope of Dreams
0
393
549
548
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|[[Anomaly|The anomaly]] represents a profound and dangerous space-time phenomenon, its expanding radius a constant threat to the stability and integrity of the entire structure. Its presence is a reminder of the fragility of order in the face of an unrelenting, chaotic force that plagues [[Omnistructure|the Omnistructure]], erasing all that it touches.
}}
== Location ==
{{coords|5310|2116|-1450}}
Found in the [[Anomaly]] area, located right in front of the anomaly itself at the final part of the labyrinth.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
e9b3658c5073f52f9811e41c238dc70edd1b8e24
Vermillion
0
394
551
550
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|An omnipresent presence bathed everything in a deep vermillion{{note|"Vermillion" here refers to the color, although it might be more commonly spelled as "vermilion" (with only one L).}} hue. This color created an overwhelming sense of order. The vermillion presence exuded a serene yet unsettling stillness, embodying an ideal form of tranquility. It seemed to impose a perfect structure on the disarray around it, its calm nature hiding an underlying menace. The more you focused on the vermillion form, the more it became clear that this serenity was a guise, concealing a power that could shatter the delicate balance at play.
}}
== Location ==
{{coords|483|-4883|1752}}
Found in the [[Vermillion Fields]], on top of a balcony with a [[Vermillion Knight]] guarding it. Standing at the [[Homunculus]], face the direction of [[The Handler]] and the balcony can be seen behind her.
== See also ==
* [[Vermillion Fields]], for the endgame location
* [[Vermillion Knight]], for the enemy
== Notes ==
{{notelist}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
989e673b86ad80578a904518b93dcddaf305e173
A Broken Reality
0
395
553
552
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|The landscape is filled with soothing, warm tones that evoke a sense of perfect calm and harmony. Yet, despite the stunning serenity, there is an unshakable feeling of not being alone, a subtle but persistent awareness that something else is present.
}}
== Location ==
{{coords|2368|-5079|1225}}
Found in [[Vermillion Fields]]. Start at the [[Homunculus]] and walk to where the blue lightsaber knight is. Head outside from there and get to the edge. Take a left and follow the edge until you come to a balcony on the right with the data log. Use [[Scanner|the scanner]] to help you find it more easily.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
cb804aedc9c441989a2f08a03652278a42ce02a8
Understanding
0
396
555
554
2025-08-21T17:38:34Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
| Hierarchies within various organizations reflect a fragmented understanding of the [[Omnistructure]]. These organizations, though structured, are plagued by slow progress and sporadic breakthroughs. Their efforts to decode and rebuild within this immense and confounding realm are hindered by the overwhelming scale and shifting nature of their environment
}}
== Acquisition ==
Unlocked upon speaking to [[Inquisitor Commander Alexius]] for the first time.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
58629768126fce5c895113d20c5c3433807829d2
Category:Lore
14
397
556
2025-08-21T17:39:14Z
Sharparam
284703
Created page with "Articles that deal with the [[lore]] of {{BFF}}."
wikitext
text/x-wiki
Articles that deal with the [[lore]] of {{BFF}}.
94c2e8b39ccfcef2092a51b9d9871303a81d3550
Category:Data logs
14
398
557
2025-08-21T17:39:54Z
Sharparam
284703
Created page with "[[Data logs]] in {{BFF}}."
wikitext
text/x-wiki
[[Data logs]] in {{BFF}}.
1164d38028f62e77abae5ba8cc9ff863d3ff7188
560
557
2025-08-21T17:42:04Z
Sharparam
284703
Add parent category
wikitext
text/x-wiki
[[Data logs]] in {{BFF}}.
[[Category:Lore]]
5e904cfff9956cd0b33207527c8346edd1f405f0
Category:Documents
14
399
558
2025-08-21T17:40:30Z
Sharparam
284703
Created page with "[[Documents]] in {{BFF}}."
wikitext
text/x-wiki
[[Documents]] in {{BFF}}.
cc0499616b9fa18a474694b811d013e801458f57
559
558
2025-08-21T17:40:55Z
Sharparam
284703
Add parent category
wikitext
text/x-wiki
[[Documents]] in {{BFF}}.
[[Category:Lore]]
a47d50212d62913cf87ebea2624342bb3dd85afd
Abandoned Soldier
0
400
562
561
2025-08-21T17:43:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/NPC
| image = Abandoned Soldier.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
Found in the [[Monastery#Lower|lower Monastery]], at the top of the stairs sitting next to one of the statue heads ({{coords|22476.39|-66438.91|-8856.44}}).
After defeating [[Konrad the Traitor]], he moves to {{TODO|Add second location}}.
At some point, he disappears entirely from the game.
{{Navbox/NPCs}}
e596f1f08e1e0d7bb6ddf38f363f5924a5b8dd01
Archinquisitor Belisarius
0
401
564
563
2025-08-21T17:43:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Archinquisitor Belisarius (boss)}}
{{stub}}
{{Infobox/NPC
| image = Archinquisitor Belisarius.png
}}
{{Navbox/NPCs}}
7acff4eb5df9236854d4caf127e0613b0980b80d
Inquisitor Commander Alexius
0
402
566
565
2025-08-21T17:43:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/NPC
| image = Inquisitor Commander Alexius.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|-41635.32|9075.12|11831.71}}
Located in the [[Asylum]], in a tower that can be reached by following a hidden path.
== Quotes ==
=== On first meeting ===
{{Quote
|Hmmm – a visitor.
A visitor to a plague at that – a rare occurence{{sic|expected=occurrence}}. Ah! The Administration? Yes – that much is now obvious.
Always a pervasive need for the world to make sense – but with each passing moment, I find the [[omnistructure]] is always one step beyond it… beyond comprehension.
I wonder what tales you'd share if only you could speak. Traversing every crevice and ruin on foot, my, my… the secrets you hold… and what happens to the ones you leave behind? Do you ever think of them?
It sounds like a treacherous life… You must not know much kindness. And how could you – I imagine you've experienced pain and death uncountable times. It is after all reflected in your demeanour.
Maybe this can make a small change. <!-- Gives greater crystals -->
You know, I myself am not a stranger to challenges. This struggle between absolute power and perfect order is no longer easy to balance. I find myself giving it my all, without, seeing much in return…
[[The Serdars]] now complicate things… Their sacrifices were too great for a wavering Empire. Yet rebelling against everything makes life lose its purpose…
[[The Administration|The Administration's]] vision of order is sterile however… perfect, yes, but like marble – its beauty frozen permanently in the rhythm of death. In his few moments of peace, [[Yaroslav]] would probably explain it better than I – then again – his word was always as sharp as his saber.
We both have work to do. Until we meet again.
}}
Unlocks the data log [[Understanding]] and gives you two [[Greater Anomalous Crystal|Greater Anomalous Crystals]].
=== After first encounter ===
{{Quote|We both have work to do. Until we meet again}}
{{Navbox/NPCs}}
39b57600330ffb5ca7e6c437458be303142ceb91
Yaroslav
0
403
568
567
2025-08-21T17:43:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/NPC
| image = Yaroslav.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|3721|1150|-1397}}
Located in the [[Desert]]. Standing with his crew in front of the gate to [[The Anomaly]].
== Quotes ==
=== First encounter ===
{{Quote
|Welcome to [[The Anomaly|the anomaly]]. The dream of uncertainty. Here, even reality amounts to nothing.
Time is not of the essence here… Only choice. Soon, you'll feel it yourself.
Sometimes, I hear it all again. The voice of a girl… The color of her eyes… Frightening yet beautiful… Like mornings at war. Hours before the storm… You breathe in deeply, for it may be your last. The vast sky… And between the cold air and the smoke, a ray of sunshine on your face…
Beyond those gates, you will have to carry the greatest burden of all – your own!
The crusade they've mustered is blind with power… my own kind, crippled by ignorance… we are lost… lost in the wilderness!
I have not seen her for so long, I wonder if she was even real… A daughter imagined in dreams perhaps… Winds be with her.
I too am tired, but I gaze into the fire as it burns slowly – my eyes wide open. Some moths gather around the flame and they fly straight into it. Others fly in too and even more follow… All night long, without as much as a rustle, they melt away… I did not fear death then… but I was beginning to fear for my life.
We enslaved what was left of the Forsaken… We crucified the Mechanomads for raiding time itself… We brought light to darkness and blinded all who refused to see… And even here, at the gates to the anomaly, we flay all who dare approach. You understand such methods… After all, your own path is a river of blood and deception…
When you return, Collector, things will not be as they were. You will not be as you were.
}}
=== After first encounter ===
{{Quote|When you return, Collector, things will not be as they were. You will not be as you were.}}
=== Cutscene when leaving the [[Desert]] to enter the [[Anomaly]] ===
{{Quote
|Things have been set in motion that can never be explained.
An eternal rain is coming our way – remember to trust your blade. You will need it more than ever.
}}
{{Navbox/NPCs}}
6bb0d94919bf2b14a91b7fd37736740fa5038de0
Royal Division Captain Yulia
0
404
570
569
2025-08-21T17:43:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Royal Division Captain Yulia & Vermillion Mirage}}
{{Infobox/NPC
| image = Royal Division Captain Yulia.png
}}
{{stub}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
{{Navbox/NPCs}}
47c5320bb535502d6ea086d13c44e3827509697f
Abelard the Brave
0
405
572
571
2025-08-21T17:43:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/NPC
| image = Abelard the Brave.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|3566.32|32790.88|-14128.63}}
Stands on the edge of a platform at the top of the [[Machinarium]].
== Quotes ==
=== First encounter ===
{{Quote
|Gets lonely out here. Thank the [[God-Emperor]] for the voices that haunt me…
Who knows what [[Yaroslav]] is up to. To turn on his own… so brutally. Tsss!
[[Serdar]] filth!
No order to this place. There's no cycle, no ebb and flow to the city. It all feels like… Eh. What do you care anyway.
War is Hell. Not a sewer, so I don't exactly know what you{{note|The voice actor emphasis the "you" in this sentence, but the subtitles do not.}} are doing here.
We all have our role to play. You play yours. We'll see about mine!
Farewell.
}}
=== Upon speaking to him again ===
{{Quote|Farewell.}}
== Notes ==
{{notelist}}
{{Navbox/NPCs}}
bff64714017d7cf963314a972d069174724842aa
Bleak Faith: Forsaken
0
406
573
2025-08-21T17:44:23Z
Sharparam
284703
Created page with "'''''{{PAGENAME}}''''' is an action role-playing game (ARPG) game by [[Archangel Studios]]. == Soundtrack == {{Main|Bleak Faith: Forsaken Original Soundtrack}} == External links == * [http://www.bleakfaith.com/ Official website] ('''Note:''' [[wikipedia:HTTPS|HTTPS]] is not available.) * [https://store.steampowered.com/app/1173220/Bleak_Faith_Forsaken/ Steam] * [https://www.gog.com/en/game/bleak_faith_forsaken GOG] * [https://www.facebook.com/bleakfaith/ Facebook] * [..."
wikitext
text/x-wiki
'''''{{PAGENAME}}''''' is an action role-playing game (ARPG) game by [[Archangel Studios]].
== Soundtrack ==
{{Main|Bleak Faith: Forsaken Original Soundtrack}}
== External links ==
* [http://www.bleakfaith.com/ Official website] ('''Note:''' [[wikipedia:HTTPS|HTTPS]] is not available.)
* [https://store.steampowered.com/app/1173220/Bleak_Faith_Forsaken/ Steam]
* [https://www.gog.com/en/game/bleak_faith_forsaken GOG]
* [https://www.facebook.com/bleakfaith/ Facebook]
* [https://x.com/bleak_faith X (Twitter)]
* [https://www.youtube.com/channel/UCmXqWlyuVHvoru4WBdz88Eg/about?view_as=subscriber YouTube]
* [https://www.instagram.com/bleakfaithofficial/ Instagram]
* [https://steamdb.info/app/1173220/ SteamDB]
* [[wikidata:Q117074729|Wikidata]]
4d0375085e030286814ed6e0805f35cfbfb349cb
Module:Duration
828
412
584
2025-08-21T17:55:50Z
Sharparam
284703
Load styles in module
Scribunto
text/plain
---Duration module
---@module DurationModule
---@alias p
local getArgs = require('Module:Arguments').getArgs
local ARG_OPTS = {
wrappers = {
"Template:Duration"
}
}
---@class Duration
---@field h
---@field m
---@field s
---@type Duration
local ZERO = { h = 0, m = 0, s = 0 }
---@type int[][]
local LOOKUP = {
[1] = { 0, 0, 1 },
[2] = { 0, 1, 2 },
[3] = { 1, 2, 3 }
}
local p = {}
---@param args any
---@return Duration
local function parseDuration(args)
local h = tonumber(args.h or args[1])
local m = tonumber(args.m or args[2])
local s = tonumber(args.s or args[3])
if h or m or s then
return {
h = h or 0,
m = m or 0,
s = s or 0
} --[[@as Duration]]
end
local input = args[1]
if not input or input == "" then return ZERO end
local parts = {}
for part in string.gmatch(input, "%d+") do
parts[#parts + 1] = tonumber(part) or 0
end
local size = #parts
return {
h = parts[LOOKUP[size][1]] or 0,
m = parts[LOOKUP[size][2]] or 0,
s = parts[LOOKUP[size][3]] or 0
} --[[@as Duration]]
end
---@param duration Duration
---@return string
local function toisostring(duration)
return string.format("PT%dH%dM%dS", duration.h, duration.m, duration.s)
end
---@param duration Duration
---@return string
local function todisplaystring(duration)
if duration.h > 0 then
return string.format("%02d:%02d:%02d", duration.h, duration.m, duration.s)
end
return string.format("%02d:%02d", duration.m, duration.s)
end
---@param frame any
---@return any
function p.main(frame)
local args = getArgs(frame, ARG_OPTS)
return p._main(args, function(s) return frame:preprocess(s) end)
end
function p._main(args, preprocess)
preprocess = preprocess or function(s) return s end
local duration = parseDuration(args)
local iso = toisostring(duration)
local display
local is_custom_display = false
if args.display then
display = preprocess(args.display)
is_custom_display = true
else
display = todisplaystring(duration)
end
local elem = mw.html.create('time')
:attr('datetime', iso)
:addClass('duration')
:wikitext(display)
if is_custom_display then
elem:attr('title', todisplaystring(duration))
:addClass('dotted')
end
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles', args = { src = 'Module:Duration/styles.css' }
} .. tostring(elem)
end
return p
01e406e1f427ec21571803ddbb608db84f5fb51a
585
584
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
---Duration module
---@module DurationModule
---@alias p
local getArgs = require('Module:Arguments').getArgs
local ARG_OPTS = {
wrappers = {
"Template:Duration"
}
}
---@class Duration
---@field h
---@field m
---@field s
---@type Duration
local ZERO = { h = 0, m = 0, s = 0 }
---@type int[][]
local LOOKUP = {
[1] = { 0, 0, 1 },
[2] = { 0, 1, 2 },
[3] = { 1, 2, 3 }
}
local p = {}
---@param args any
---@return Duration
local function parseDuration(args)
local h = tonumber(args.h or args[1])
local m = tonumber(args.m or args[2])
local s = tonumber(args.s or args[3])
if h or m or s then
return {
h = h or 0,
m = m or 0,
s = s or 0
} --[[@as Duration]]
end
local input = args[1]
if not input or input == "" then return ZERO end
local parts = {}
for part in string.gmatch(input, "%d+") do
parts[#parts + 1] = tonumber(part) or 0
end
local size = #parts
return {
h = parts[LOOKUP[size][1]] or 0,
m = parts[LOOKUP[size][2]] or 0,
s = parts[LOOKUP[size][3]] or 0
} --[[@as Duration]]
end
---@param duration Duration
---@return string
local function toisostring(duration)
return string.format("PT%dH%dM%dS", duration.h, duration.m, duration.s)
end
---@param duration Duration
---@return string
local function todisplaystring(duration)
if duration.h > 0 then
return string.format("%02d:%02d:%02d", duration.h, duration.m, duration.s)
end
return string.format("%02d:%02d", duration.m, duration.s)
end
---@param frame any
---@return any
function p.main(frame)
local args = getArgs(frame, ARG_OPTS)
return p._main(args, function(s) return frame:preprocess(s) end)
end
function p._main(args, preprocess)
preprocess = preprocess or function(s) return s end
local duration = parseDuration(args)
local iso = toisostring(duration)
local display
local is_custom_display = false
if args.display then
display = preprocess(args.display)
is_custom_display = true
else
display = todisplaystring(duration)
end
local elem = mw.html.create('time')
:attr('datetime', iso)
:addClass('duration')
:wikitext(display)
if is_custom_display then
elem:attr('title', todisplaystring(duration))
:addClass('dotted')
end
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles', args = { src = 'Module:Duration/styles.css' }
} .. tostring(elem)
end
return p
01e406e1f427ec21571803ddbb608db84f5fb51a
Module:Duration/styles.css
828
411
582
2025-08-21T17:56:26Z
Sharparam
284703
Sharparam moved page [[Template:Duration/styles.css]] to [[Module:Duration/styles.css]] without leaving a redirect: Moving styles to module level
sanitized-css
text/css
time.duration.dotted {
border-bottom: 1px dotted;
}
3d31243ddfc10500c1050d7e08d4e4ceb60dba74
583
582
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
time.duration.dotted {
border-bottom: 1px dotted;
}
3d31243ddfc10500c1050d7e08d4e4ceb60dba74
Template:Duration
10
410
580
2025-08-21T17:57:12Z
Sharparam
284703
Fix missing start tag
wikitext
text/x-wiki
<includeonly>{{#invoke:Duration|main}}</includeonly><noinclude>{{Documentation}}</noinclude>
46a71dab33136afb3cfda922978ce2a0f128228e
581
580
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Duration|main}}</includeonly><noinclude>{{Documentation}}</noinclude>
46a71dab33136afb3cfda922978ce2a0f128228e
Template:Track listing
10
407
575
574
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{#invoke:Track listing|main}}<noinclude>
{{documentation}}
</noinclude>
bef48fe7b046d2e4f4a2ed058a47e1ec3b30ed00
Module:Track listing
828
408
577
576
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
local yesno = require('Module:Yesno')
local checkType = require('libraryUtil').checkType
local cfg = mw.loadData('Module:Track listing/configuration')
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
-- Add a mixin to a class.
local function addMixin(class, mixin)
for k, v in pairs(mixin) do
if k ~= 'init' then
class[k] = v
end
end
end
--------------------------------------------------------------------------------
-- Validation mixin
--------------------------------------------------------------------------------
local Validation = {}
function Validation.init(self)
self.warnings = {}
self.categories = {}
end
function Validation:addWarning(msg, category)
table.insert(self.warnings, msg)
table.insert(self.categories, category)
end
function Validation:addCategory(category)
table.insert(self.categories, category)
end
function Validation:getWarnings()
return self.warnings
end
function Validation:getCategories()
return self.categories
end
-- Validate a track length. If a track length is invalid, a warning is added.
-- A type error is raised if the length is not of type string or nil.
function Validation:validateLength(length)
checkType('validateLength', 1, length, 'string', true)
if length == nil then
-- Do nothing if no length specified
return nil
end
local hours, minutes, seconds
-- Try to match times like "1:23:45".
hours, minutes, seconds = length:match('^(%d+):(%d%d):(%d%d)$')
if hours and hours:sub(1, 1) == '0' then
-- Disallow times like "0:12:34"
self:addWarning(
string.format(cfg.leading_0_in_hours, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
if not seconds then
-- The previous attempt didn't match. Try to match times like "1:23".
minutes, seconds = length:match('^(%d?%d):(%d%d)$')
if minutes and minutes:find('^0%d$') then
-- Special case to disallow lengths like "01:23". This check has to
-- be here so that lengths like "1:01:23" are still allowed.
self:addWarning(
string.format(cfg.leading_0_in_minutes, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
end
-- Add a warning and return if we did not find a match.
if not seconds then
self:addWarning(
string.format(cfg.not_a_time, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
-- Check that the minutes are less than 60 if we have an hours field.
if hours and tonumber(minutes) >= 60 then
self:addWarning(
string.format(cfg.more_than_60_minutes, mw.text.nowiki(length)),
cfg.input_error_category
)
return nil
end
-- Check that the seconds are less than 60
if tonumber(seconds) >= 60 then
self:addWarning(
string.format(cfg.more_than_60_seconds, mw.text.nowiki(length)),
cfg.input_error_category
)
end
return nil
end
--------------------------------------------------------------------------------
-- Track class
--------------------------------------------------------------------------------
local Track = {}
Track.__index = Track
addMixin(Track, Validation)
Track.fields = cfg.track_field_names
Track.cellMethods = {
number = 'makeNumberCell',
title = 'makeTitleCell',
writer = 'makeWriterCell',
lyrics = 'makeLyricsCell',
music = 'makeMusicCell',
extra = 'makeExtraCell',
length = 'makeLengthCell',
}
function Track.new(data)
local self = setmetatable({}, Track)
Validation.init(self)
for field in pairs(Track.fields) do
self[field] = data[field]
end
self.number = assert(tonumber(self.number))
self:validateLength(self.length)
return self
end
function Track:getLyricsCredit()
return self.lyrics
end
function Track:getMusicCredit()
return self.music
end
function Track:getWriterCredit()
return self.writer
end
function Track:getExtraField()
return self.extra
end
-- Note: called with single dot syntax
function Track.makeSimpleCell(wikitext)
return mw.html.create('td')
:wikitext(wikitext or cfg.blank_cell)
end
function Track:makeNumberCell()
return mw.html.create('th')
:attr('id', string.format(cfg.track_id, self.number))
:attr('scope', 'row')
:wikitext(string.format(cfg.number_terminated, self.number))
end
function Track:makeTitleCell()
local titleCell = mw.html.create('td')
titleCell:wikitext(
self.title and string.format(cfg.track_title, self.title) or cfg.untitled
)
if self.note then
titleCell:wikitext(string.format(cfg.note, self.note))
end
return titleCell
end
function Track:makeWriterCell()
return Track.makeSimpleCell(self.writer)
end
function Track:makeLyricsCell()
return Track.makeSimpleCell(self.lyrics)
end
function Track:makeMusicCell()
return Track.makeSimpleCell(self.music)
end
function Track:makeExtraCell()
return Track.makeSimpleCell(self.extra)
end
function Track:makeLengthCell()
return mw.html.create('td')
:addClass('tracklist-length')
:wikitext(self.length or cfg.blank_cell)
end
function Track:exportRow(columns)
local columns = columns or {}
local row = mw.html.create('tr')
for i, column in ipairs(columns) do
local method = Track.cellMethods[column]
if method then
row:node(self[method](self))
end
end
return row
end
--------------------------------------------------------------------------------
-- TrackListing class
--------------------------------------------------------------------------------
local TrackListing = {}
TrackListing.__index = TrackListing
addMixin(TrackListing, Validation)
TrackListing.fields = cfg.track_listing_field_names
TrackListing.deprecatedFields = cfg.deprecated_track_listing_field_names
function TrackListing.new(data)
local self = setmetatable({}, TrackListing)
Validation.init(self)
-- Check for deprecated arguments
for deprecatedField in pairs(TrackListing.deprecatedFields) do
if data[deprecatedField] then
self:addCategory(cfg.deprecated_parameter_category)
break
end
end
-- Validate total length
if data.total_length then
self:validateLength(data.total_length)
end
-- Add properties
for field in pairs(TrackListing.fields) do
self[field] = data[field]
end
-- Evaluate boolean properties
self.showCategories = yesno(self.category) ~= false
self.category = nil
-- Make track objects
self.tracks = {}
for i, trackData in ipairs(data.tracks or {}) do
table.insert(self.tracks, Track.new(trackData))
end
-- Find which of the optional columns we have.
-- We could just check every column for every track object, but that would
-- be no fun^H^H^H^H^H^H inefficient, so we use four different strategies
-- to try and check only as many columns and track objects as necessary.
do
local optionalColumns = {}
local columnMethods = {
lyrics = 'getLyricsCredit',
music = 'getMusicCredit',
writer = 'getWriterCredit',
extra = 'getExtraField',
}
local doneWriterCheck = false
for i, trackObj in ipairs(self.tracks) do
for column, method in pairs(columnMethods) do
if trackObj[method](trackObj) then
optionalColumns[column] = true
columnMethods[column] = nil
end
end
if not doneWriterCheck and optionalColumns.writer then
doneWriterCheck = true
optionalColumns.lyrics = nil
optionalColumns.music = nil
columnMethods.lyrics = nil
columnMethods.music = nil
end
if not next(columnMethods) then
break
end
end
self.optionalColumns = optionalColumns
end
return self
end
--------------------------------------------------------------------------------
-- Function for automatic punctuation for parameters:
-- all_writing, all_lyrics, all_music
-- Punctuation defaults to '.' unless ':' or '.' already exist
-- Automatic punctuation limited to parameter values not containing parser tags
-- i.e. <ref>Text</ref>, <nowiki></nowiki>, etc.
--------------------------------------------------------------------------------
function fullstop(a)
if a ~= mw.text.killMarkers(mw.getCurrentFrame():preprocess(a)) or
a:sub(-1,-1) == ":" or
a:sub(-1,-1) == "." then
return a
else
return a .. '.'
end
end
function TrackListing:makeIntro()
if self.all_writing then
return string.format(cfg.tracks_written, fullstop(self.all_writing))
elseif self.all_lyrics and self.all_music then
return mw.message.newRawMessage(
cfg.lyrics_written_music_composed,
self.all_lyrics,
fullstop(self.all_music)
):plain()
elseif self.all_lyrics then
return string.format(cfg.lyrics_written, fullstop(self.all_lyrics))
elseif self.all_music then
return string.format(cfg.music_composed, fullstop(self.all_music))
else
return nil
end
end
function TrackListing:renderTrackingCategories()
if not self.showCategories or mw.title.getCurrentTitle().namespace ~= 0 then
return ''
end
local ret = ''
local function addCategory(cat)
ret = ret .. string.format('[[Category:%s]]', cat)
end
for i, category in ipairs(self:getCategories()) do
addCategory(category)
end
for i, track in ipairs(self.tracks) do
for j, category in ipairs(track:getCategories()) do
addCategory(category)
end
end
return ret
end
function TrackListing:renderWarnings()
if not cfg.show_warnings then
return ''
end
local ret = {}
local function addWarning(msg)
table.insert(ret, string.format(cfg.track_listing_error, msg))
end
for i, warning in ipairs(self:getWarnings()) do
addWarning(warning)
end
for i, track in ipairs(self.tracks) do
for j, warning in ipairs(track:getWarnings()) do
addWarning(warning)
end
end
return table.concat(ret, '<br>')
end
function TrackListing:__tostring()
-- Root of the output
local root = mw.html.create('div')
:addClass('track-listing')
local intro = self:makeIntro()
if intro then
root:tag('p')
:wikitext(intro)
:done()
end
-- Start of track listing table
local tableRoot = mw.html.create('table')
tableRoot
:addClass('tracklist')
-- Overall table width
if self.width then
tableRoot
:css('width', self.width)
end
-- Header row
if self.headline then
tableRoot:tag('caption')
:wikitext(self.headline or cfg.track_listing)
end
-- Headers
local headerRow = tableRoot:tag('tr')
---- Track number
headerRow
:tag('th')
:addClass('tracklist-number-header')
:attr('scope', 'col')
:tag('abbr')
:attr('title', cfg.number)
:wikitext(cfg.number_abbr)
-- Find columns to output
local columns = {'number', 'title'}
if self.optionalColumns.writer then
columns[#columns + 1] = 'writer'
else
if self.optionalColumns.lyrics then
columns[#columns + 1] = 'lyrics'
end
if self.optionalColumns.music then
columns[#columns + 1] = 'music'
end
end
if self.optionalColumns.extra then
columns[#columns + 1] = 'extra'
end
columns[#columns + 1] = 'length'
-- Find column width
local nColumns = #columns
local nOptionalColumns = nColumns - 3
local titleColumnWidth = 100
if nColumns >= 5 then
titleColumnWidth = 40
elseif nColumns >= 4 then
titleColumnWidth = 60
end
local optionalColumnWidth = ((100 - titleColumnWidth) / nOptionalColumns) .. '%'
titleColumnWidth = titleColumnWidth .. '%'
---- Title column
headerRow:tag('th')
:attr('scope', 'col')
:css('width', self.title_width or titleColumnWidth)
:wikitext(cfg.title)
---- Optional headers: writer, lyrics, music, and extra
local function addOptionalHeader(field, headerText, width)
if self.optionalColumns[field] then
headerRow:tag('th')
:attr('scope', 'col')
:css('width', width or optionalColumnWidth)
:wikitext(headerText)
end
end
addOptionalHeader('writer', cfg.writer, self.writing_width)
addOptionalHeader('lyrics', cfg.lyrics, self.lyrics_width)
addOptionalHeader('music', cfg.music, self.music_width)
addOptionalHeader(
'extra',
self.extra_column or cfg.extra,
self.extra_width
)
---- Track length
headerRow:tag('th')
:addClass('tracklist-length-header')
:attr('scope', 'col')
:wikitext(cfg.length)
-- Tracks
for i, track in ipairs(self.tracks) do
tableRoot:node(track:exportRow(columns))
end
-- Total length
if self.total_length then
tableRoot
:tag('tr')
:addClass('tracklist-total-length')
:tag('th')
:attr('colspan', nColumns - 1)
:attr('scope', 'row')
:tag('span')
:wikitext(cfg.total_length)
:done()
:done()
:tag('td')
:wikitext(self.total_length)
end
root:node(tableRoot)
-- Warnings and tracking categories
root:wikitext(self:renderWarnings())
root:wikitext(self:renderTrackingCategories())
return mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Module:Track listing/styles.css' }
} .. tostring(root)
end
--------------------------------------------------------------------------------
-- Exports
--------------------------------------------------------------------------------
local p = {}
function p._main(args)
-- Process numerical args so that we can iterate through them.
local data, tracks = {}, {}
for k, v in pairs(args) do
if type(k) == 'string' then
local prefix, num = k:match('^(%D.-)(%d+)$')
if prefix and Track.fields[prefix] and (num == '0' or num:sub(1, 1) ~= '0') then
-- Allow numbers like 0, 1, 2 ..., but not 00, 01, 02...,
-- 000, 001, 002... etc.
num = tonumber(num)
tracks[num] = tracks[num] or {}
tracks[num][prefix] = v
else
data[k] = v
end
end
end
data.tracks = (function (t)
-- Compress sparse array
local ret = {}
for num, trackData in pairs(t) do
trackData.number = num
table.insert(ret, trackData)
end
table.sort(ret, function (t1, t2)
return t1.number < t2.number
end)
return ret
end)(tracks)
return tostring(TrackListing.new(data))
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame, {
wrappers = 'Template:Track listing'
})
return p._main(args)
end
return p
ba53211a0ca356f872c9a88324fd2a6a9e8ff30a
Module:Track listing/configuration
828
409
579
578
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
return {
show_warnings = false,
input_error_category = 'Track listings with input errors',
collapsed_parameter_category = 'Track listings that use the collapsed parameter ',
deprecated_parameter_category = 'Track listings with deprecated parameters',
track_field_names = {
number = true,
title = true,
note = true,
length = true,
lyrics = true,
music = true,
writer = true,
extra = true,
},
track_listing_field_names = {
width = true,
headline = true,
all_writing = true,
all_lyrics = true,
all_music = true,
extra_column = true,
total_length = true,
title_width = true,
writing_width = true,
lyrics_width = true,
music_width = true,
extra_width = true,
category = true,
},
deprecated_track_listing_field_names = {
writing_credits = true,
lyrics_credits = true,
music_credits = true,
},
leading_0_in_hours = "Invalid time '%s' (times in format 'h:mm:ss' cannot start with zero)",
leading_0_in_minutes = "Invalid time '%s' (times in format 'mm:ss' cannot start with zero)",
not_a_time = "Invalid time '%s' (times must be in a format of 'm:ss', 'mm:ss' or 'h:mm:ss')",
more_than_60_minutes = "Invalid track length '%s' (if hours are specified, the number of minutes must be less than 60)",
more_than_60_seconds = "Invalid track length '%s' (number of seconds must be less than 60)",
tracks_written = 'All tracks are written by %s',
lyrics_written_music_composed = 'All lyrics are written by $1; all music is composed by $2',
lyrics_written = 'All lyrics are written by %s',
music_composed = 'All music is composed by %s',
track_listing_error = '<strong class="error">Track listing error: %s</strong>',
deprecated_collapsed = 'Deprecated collapsed parameter in use.',
title = 'Title',
number = 'Number',
number_abbr = 'No.',
track_listing = 'Track listing',
writer = 'Writer(s)',
lyrics = 'Lyrics',
music = 'Music',
extra = '{{{extra_column}}}',
length = 'Length',
blank_cell = ' ',
track_title = '"%s"',
untitled = 'Untitled',
note = ' (%s)',
track_id = 'track%d',
number_terminated = '%d.',
total_length = 'Total length:'
}
5fcb26176f1458c5fdb9b1ba7af4cafc73cbd05a
Bleak Faith: Forsaken Original Soundtrack
0
413
587
586
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is a collection of songs that play throughout {{BFF}}. It is composed by [[Martel]] and [[Rade Vukčević]].
The soundtrack contains 44 tracks across all three discs with a combined total runtime of {{Duration|3:30:00|display=three and a half hours}}.
== Songs ==
<!--
// Generated using the following script on the Apple Music page:
(function() {
const discs = document.querySelectorAll('.section--disc');
console.debug(discs);
for (const disc of discs) {
const header = disc.querySelector('.disc-header h2.title').textContent;
const songs = disc.querySelectorAll('.songs-list .songs-list-row');
let total_length = 0;
const songData = Array.from(songs).map(s => {
const no = s.querySelector('.songs-list-row__song-index .songs-list-row__column-data').textContent;
const title = s.querySelector('.songs-list-row__song-name').textContent;
const length = s.querySelector('.songs-list-row__length').textContent;
const [mins, secs] = length.split(':').map(l => Number(l));
total_length += mins * 60 + secs;
return `| title${no} = ${title}\n| length${no} = ${length}`;
});
const tracks = songData.join("\n\n");
const tot_hors = Math.floor(total_length / 60 / 60);
const tot_mins = Math.floor((total_length - tot_hors * 60 * 60) / 60);
const tot_secs = total_length % 60;
const entry = `{{Track listing\n| headline = ${header}\n| total_length = ${tot_hors}:${tot_mins}:${tot_secs}\n\n${tracks}\n}}`;
console.info(entry);
}
})();
-->
{{Track listing
| headline = Disc 1
| total_length = 1:49:26
| title1 = Premonitions
| length1 = 3:19
| title2 = The Monastery
| length2 = 8:22
| title3 = Oathsworn
| length3 = 4:25
| title4 = The Imperial Siege
| length4 = 3:25
| title5 = Concrete Sea
| length5 = 4:32
| title6 = Sky Towers
| length6 = 9:23
| title7 = Downpour
| length7 = 9:12
| title8 = The Serdars
| length8 = 8:59
| title9 = The Inquisition
| length9 = 5:31
| title10 = The Valley
| length10 = 3:34
| title11 = The Trisagion
| length11 = 2:12
| title12 = Cloaca Maxima
| length12 = 3:15
| title13 = The Call of the Void
| length13 = 7:45
| title14 = The Machinarium
| length14 = 11:36
| title15 = A Bitter Evening
| length15 = 3:58
| title16 = Dreamlight
| length16 = 7:32
| title17 = The Instinct
| length17 = 2:27
| title18 = Recycled
| length18 = 3:00
| title19 = Domus Aurea
| length19 = 6:59
}}
{{Track listing
| headline = Disc 2
| total_length = 48:46
| title1 = Aurelian
| length1 = 5:31
| title2 = Vangelian
| length2 = 4:13
| title3 = Machinebirth
| length3 = 4:52
| title4 = Melanion
| length4 = 6:15
| title5 = Oberon
| length5 = 5:10
| title6 = Serapian
| length6 = 5:35
| title7 = Limitless
| length7 = 4:54
| title8 = The Fade
| length8 = 2:42
| title9 = Wandering
| length9 = 4:50
| title10 = Machinedream
| length10 = 4:44
}}
{{Track listing
| headline = Disc 3
| total_length = 52:11
| title1 = The Mountain Wreath
| length1 = 2:21
| title2 = Destiny
| length2 = 8:45
| title3 = Saberstorm
| length3 = 2:59
| title4 = Yaroslav's Rebellion
| length4 = 5:09
| title5 = The Nightmare (Menu Theme)
| length5 = 2:27
| title6 = Konrad the Traitor
| length6 = 2:49
| title7 = Yuliya
| length7 = 2:53
| title8 = Nemesis
| length8 = 3:04
| title9 = Belisarius
| length9 = 3:18
| title10 = Aberrant Knight
| length10 = 3:02
| title11 = Nurgei
| length11 = 3:15
| title12 = Wormlord
| length12 = 3:53
| title13 = Wyvern's Lament
| length13 = 3:52
| title14 = Doppelganger
| length14 = 2:22
| title15 = Baryak
| length15 = 2:02
}}
== External links ==
* [https://open.spotify.com/album/1cORrZ4GAVDbMvbEbvEL4q Spotify]
* [https://music.apple.com/ua/album/bleak-faith-original-soundtrack/1678680781 Apple Music]
* [https://martelvladimiroff.bandcamp.com/album/bleak-faith-forsaken Bandcamp]
d8060222851027ad9a4b2724ead306d2de16f292
Module:Track listing/styles.css
828
414
589
588
2025-08-21T17:59:12Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
/* {{pp|small=y}} */
.tracklist {
border-spacing: 0;
}
/* set on all rows we can set the total length row to transparent */
.tracklist tr {
background-color: var(--background-color-base, #fff);
}
.tracklist tr:nth-child(2n-1) {
background-color: var(--background-color-neutral-subtle, #f8f9fa);
}
.tracklist caption {
text-align: left;
font-weight: bold;
}
.tracklist td,
.tracklist th[scope="row"] {
vertical-align: top;
}
.tracklist th[scope="col"] {
text-align: left;
background-color: var(--background-color-neutral, #eaecf0);
}
.tracklist th.tracklist-length-header,
.tracklist th.tracklist-number-header,
.tracklist th[scope="row"],
.tracklist-length,
.tracklist-total-length td {
padding-right: 10px;
text-align: right;
}
.tracklist th[scope="row"] {
font-weight: normal;
}
.tracklist-number-header {
width: 2em;
padding-left: 10px;
}
.tracklist-length-header {
width: 4em;
}
.tracklist tr.tracklist-total-length {
background-color: transparent;
}
.tracklist .tracklist-total-length th {
padding: 0;
font-weight: bold;
}
.tracklist-total-length th > span {
float: right;
padding: 0 10px;
background-color: var(--background-color-neutral, #eaecf0);
}
.tracklist-total-length td {
background-color: var(--background-color-neutral, #eaecf0);
font-weight: bold;
padding: 0 10px 0 0;
}
bc12ba45209a6a001e4bfaed9bda7f8aff5d3334
Module:Hatnote/styles.css
828
415
590
2025-08-21T18:00:01Z
Sharparam
284703
Created page with "/* {{pp|small=y}} */ .hatnote { font-style: italic; } /* Limit structure CSS to divs because of [[Module:Hatnote inline]] */ div.hatnote { /* @noflip */ padding-left: 1.6em; margin-bottom: 0.5em; } .hatnote i { font-style: normal; } /* The templatestyles element inserts a link element before hatnotes. * TODO: Remove link if/when WMF resolves T200206 */ .hatnote + link + .hatnote { margin-top: -0.5em; } @media print { body.ns-0 .hatnote { display: none !impo..."
sanitized-css
text/css
/* {{pp|small=y}} */
.hatnote {
font-style: italic;
}
/* Limit structure CSS to divs because of [[Module:Hatnote inline]] */
div.hatnote {
/* @noflip */
padding-left: 1.6em;
margin-bottom: 0.5em;
}
.hatnote i {
font-style: normal;
}
/* The templatestyles element inserts a link element before hatnotes.
* TODO: Remove link if/when WMF resolves T200206 */
.hatnote + link + .hatnote {
margin-top: -0.5em;
}
@media print {
body.ns-0 .hatnote {
display: none !important;
}
}
aa61a27060ce48815745f5b81624c7fd95b51b82
Bleak Faith: Forsaken Wiki/about
0
6
591
11
2025-08-21T18:02:04Z
Sharparam
284703
Link to BFF article
wikitext
text/x-wiki
{{Main page box/start
| title = About [[Bleak Faith: Forsaken]]
}}
This is an example main page. You can redesign it however you want, or you can keep the layout the same but change the contents (e.g. this part should talk about your game). Take a look at some other wiki.gg wikis for inspiration!
<div style="text-align:right">[[Bleak Faith: Forsaken|Read more...]]</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
525e985f7465f983b7dbfb9dc8b65b3a47787c0b
Bleak Faith: Forsaken Wiki/pages
0
5
592
9
2025-08-21T18:04:17Z
Sharparam
284703
Improve example links
wikitext
text/x-wiki
{{Main page box/start
| title = Useful wiki pages
| class = centered-content
}}
<div class="mp-links columns-2">
* {{MP link|Items!}}
* {{MP link|Random page|link=Special:Random}}
* {{MP link|Example character|link=The Handler}}
* {{MP link|Example weapon|link=Katanas|image=Katanas.png|size=92px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
ee9c73ccd6857df2fd240662164ee1044bcd17b3
593
592
2025-08-21T18:05:07Z
Sharparam
284703
Fix link to items
wikitext
text/x-wiki
{{Main page box/start
| title = Useful wiki pages
| class = centered-content
}}
<div class="mp-links columns-2">
* {{MP link|Items!|link=Items}}
* {{MP link|Random page|link=Special:Random}}
* {{MP link|Example character|link=The Handler}}
* {{MP link|Example weapon|link=Katanas|image=Katanas.png|size=92px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
8ef2b26c945f269ede16829e646573a854bdd28f
Items
0
416
595
594
2025-08-21T18:09:59Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' come in various forms, from [[equipment]] that can be worn by the player, to [[consumables]] that can be used for various effects.
{{Navbox/Items}}
f9e1d38d5ce67ef854c74e6280c1d93d64ed929f
630
595
2025-08-21T18:10:44Z
Sharparam
284703
Add category
wikitext
text/x-wiki
'''{{PAGENAME}}''' come in various forms, from [[equipment]] that can be worn by the player, to [[consumables]] that can be used for various effects.
{{Navbox/Items}}
[[Category:Items]]
5f640b156bc0e2b0a2f746a56e536f618b5120fe
Template:Infobox/Item
10
417
597
596
2025-08-21T18:09:59Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind=item
| sep=,
| image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=DescriptionSection
| DescriptionSection=Description
| DescriptionSection_label=Description
| Description_nolabel=yes
}}{{#if:{{NAMESPACE}}||[[Category:Items]]}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]</noinclude>
5d4929aef36fffdaea5150152baf68fb562131a0
Category:Essential items
14
418
599
598
2025-08-21T18:10:00Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Category:Upgrade items
14
419
601
600
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Greater Anomalous Crystal
0
420
603
602
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is an [[Items|item]] found in {{BFF}}. It can be embedded into [[weapons]] or [[armor]] to improve their properties.
== Variants ==
There are several different variants of the crystal that all share the same name in-game, differing only by their visual appearance and the effects they give when embedded into [[equipment]].
They have received ad-hoc names on the wiki temporarily to be able to differentiate them. The names are assigned based on the item's appearance.
=== "Purple jagged" ===
* '''Effect in [[armor]]:''' +25 max [[flux]] points.
* '''Effect in [[weapons]]:''' +8% [[technomancy]] penetration.
=== "Orange shield" ===
* '''Effect in [[armor]]:''' +30% base weapon damage.
* '''Effect in [[weapons]]:''' +9% attack power.
=== "Ruby" ===
* '''Effect in [[armor]]:''' +75 max health points.
* '''Effect in [[weapons]]:''' +15% critical damage.
== Locations ==
{| class="wikitable sortable"
! scope="col" | Area
! scope="col" class="unsortable" | Description
! scope="col" class="unsortable" | Coordinates
! scope="col" | Variant
|-
| [[Blok 6147]] || For now, refer to a walkthrough video on Discord.[https://discord.com/channels/541778372997677056/1087019327712133140/1087020918221590608] || {{coords|-1155|-1340|2635}} || Orange shield
|-
| [[Deluge]] || Starting from the first [[homunculus]] in the area, climb the stairs (past [[The Handler]]) and enter the small tower inhabited by a [[Diver]] [[Enemies|enemy]]. Look over the edge and you'll see a rusty walkway circling the tower. Drop down onto the walkway and follow it to the right (the direction the enemy was facing) and keep following it to find a ladder going up. Climb the ladder and continue straight to notice a gap in the floor, jump the gap and continue forward to find the crystal. (Going down the gap leads to a post-process effect unlock ("Dramatic").) || {{coords|-3178|-1346|5700}} || Purple jagged
|-
| [[Uranopolis]] || Next to a tree near the giant enemy that drops [[Ring of Casting Speed]]. || {{coords|-2185|-4082|1473}} || Orange shield
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting at the [[Homunculus]], head through the doorway and take the left path. When in the outdoors area, head up the big stairs and take the left path. At the end is a big cliff. Walk near the cliff and use the jump button repeatedly to climb to the top of the cliff. The item is on the edge of the cliff. || {{coords|1246|-8872|1517}} || Ruby
|}
{{Navbox/Items}}
[[Category:Items]]
[[Category:Anomalous crystals]]
f3dbb5471d067f2759e3b9ef743f9c6ebc7f3619
Handler Echo
0
421
605
604
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| image = Handler Echo.png
| title = {{PAGENAME}}
| Description = An obscure residue used to supplement [[The Handler|the Handler's]] capabilities. [[The Handler]] can use this to upgrade [[equipment]] more effectively.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] used to level up [[The Handler]], in order to increase the max level equipment can be upgraded to.
== Usage ==
If the item is in your inventory, [[The Handler]] will automatically level up when you next interact with her. A message will also pop up in the bottom right corner of the screen informing you of the new synchronization level.
== Acquisition ==
* Drops from [[Konrad the Traitor]].
* Can drop from samurai enemies in [[Uranopolis]] (limited to one drop).
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Rain District]] || Up some stairs. || {{coords|-36697.35|-17753.66|12174.48}}
|-
| [[Asylum]] || In the spiral staircase with the shortcut door to the courtyard there is a floating ghost. Move through the ghost and the echo will be right behind it. || {{coords|-4225|6824|9253}}
|-
| [[Desert]] || In the big building after the sand worm, where Yaroslav's crew is. The echo is sitting on a toppled pillar. || {{coords|3720|1159|-1397}}
|}
{{Navbox/Items}}
[[Category:Essential items]]
8e39742af7d396a0340cfbf20893f0518504a05a
Plagued Blood
0
422
607
606
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Plagued Blood.png
| Description = Harvested from a burial site, this unsettling vial contains a sample of plagued blood belonging to a Revenant.
}}
== Location ==
{{coords|-3898|1671|1585}}
Located at the top of the big tower in [[Asylum|the asylum]], after climbing a staircase into a room with a bunch of empty bookshelves, look to your right to see the item on a table.
== Usage ==
Having this item in your inventory allows for spawning some optional bosses.
* [[Plagued Warden]]
* [[Plagued Revenant]]
{{Navbox/Items}}
[[Category:Essential items]]
1f8d91aaf3bd07906a2a403a6db0b8ae9ee60325
Homunculus Mirage
0
423
609
608
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| tabs=Normal,Husk
| Normal_title = Homunculus Mirage
| Husk_title = Humunculus Mirage Husk
| images = [[File:Homunculus Mirage.png|300px]],[[File:Homunculus Mirage Husk.png|300px]]
| Normal_Description = The Homunculus triggers its ability only when your vital signs have ceased – reassembling your body on a molecular level elsewhere while keeping your consciousness intact, allowing for seamless and instantaneous relocation.
| Husk_Description = The husk of the Homunculus stores your current state and consciousness. Return at the Homunculus to combine the two again, allowing you to place the Homunculus elsewhere.
}}
{{Navbox/Items}}
[[Category:Essential items]]
8fb75994fa6cda97b1ebe8cfd760652188977f94
Perk Essence
0
424
611
610
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| tabs = Stable,Unstable
| images = [[File:Perk Essence.png|300px]],[[File:Unstable Perk Essence.png|300px]]
| Stable_title = Perk Essence
| Unstable_title = Unstable Perk Essence
| Stable_Description = An artifact used in the process of embedding perks.
| Unstable_Description = Get to a checkpoint to turn it into a perk, on death goes back to it's [sic] original location.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] used to acquire [[perks]] or perk upgrades.
== Acquisition ==
The unstable variant drops from some [[bosses]] (excluding mini-bosses), bringing it to a [[homunculus]] without dying stabilises it. It has to be brought to a normal homunculus, not one spawned by the [[Homunculus Mirage]].
Dying on the way to a homunculus while the item is still in its unstable form will respawn it in the boss's arena, forcing the player to go back and pick it up again.
{{Navbox/Items}}
[[Category:Essential items]]
e1971e413ec50fbb2dc150383cacbe574eece1c5
Upgrade Module
0
425
613
612
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Upgrade Module.png
| Description = A rare artifact used in the process of upgrading gear.
}}
'''{{PAGENAME}}''' is an [[Upgrade items|upgrade item]] in {{BFF}}. It is used to upgrade equipment to Mk 4 and 5.
{{Navbox/Items}}
[[Category:Essential items]]
[[Category:Upgrade items]]
f405ef0912d49ef39a269fb10d08d14c1e5322bb
Anomalous Fragment
0
426
615
614
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Anomalous Fragment.png
| Description = [[The Handler|Handler]] may convert it to a more useful form.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Acquisition ==
Drops from [[bosses]] in [[NG+]].
== Usage ==
Used to manufacture [[Greater Anomalous Crystal|Greater Anomalous Crystals]] at [[The Handler]].
[[Category:Essential items]]
7980e000ddcb82018f50487ce22ffa9df9abbde2
Anomalous crystals
0
427
617
616
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] that can be embedded into [[equipment]] ([[armor]] or [[weapons]] only) to improve their properties.
== Overview ==
There are three "tiers" of crystals: '''[[Lesser Anomalous Crystal|lesser]]''', '''[[Anomalous Crystal|normal]]''', and '''[[Greater Anomalous Crystal|greater]]'''.
Crystals can only be embedded into equipment by [[The Handler]]. Embedding a crystal into a slot destroys any crystal that is already occupying said slot, causing it to be lost forever.
{{Navbox/Items}}
[[Category:Anomalous crystals]]
5cef9dfbb687f0e77132dcb7450a11e973b25b95
Consumables
0
428
619
618
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[Items|item]] that the player can use to heal themselves, restore resources, or gain various buffs.
{{Navbox/Consumables}}
d9a89e867297dd4ee6e2667cdb541b327cdc74e4
Old Key
0
429
621
620
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Old Key.png
| Description = An old, rusted key that unlocks the gate in the old [[Monastery|monastery]].
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Location ==
{{coords|19328.57|-41596.65|3.83}}
Found at the top of the [[Monastery]], behind [[Konrad the Traitor]]. Killing the boss is not required to pick it up.
== Usage ==
Unlocks the gate at the top of the [[Monastery]], found near the entrance to [[Konrad the Traitor|Konrad the Traitor's]] boss arena (keep going past the entrance instead of entering it).
{{Navbox/Items}}
a6c6a09cf952e26c4386195a47267f9112b2ac5e
Ability Splinter
0
430
623
622
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}. It is used to equip and change [[abilities]].
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found near the [[Paladin Mace]]. Facing where the mace is, head left and slightly behind and look behind the large pillar to find the item. || {{coords|-4581|-7721|5575}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and keep right until you get to the room with a staircase going down. Before heading down the staircase, walk around it on its right and check the corner to find the item. || {{coords|1120|-7590|161}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and take the left path. In the outdoors area, head up the stairs and take the second right to get to the edge of the cliff with a bunch of graves. The item can be found near one of the graves. || {{coords|1321|-8034|190}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and take the left path. In the outdoors area, head up the stairs and take the left path to a cliff. Climb the cliff by repeatedly tapping the jump button. Once at the top, take the path leading down and follow it past a group of buildings (where the [[Soul Reaper]] can be found). Past the buildings are a set of graves with the item on top of one of them.
|}
{{Navbox/Items}}
[[Category:Essential items]]
7b6f4fe171581f79b13cd24ed99204aef452dab4
Materials
0
431
625
624
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] used to [[Crafting|craft]] or [[Manufacturing|manufacture]] other items.
{{Navbox/Materials}}
16c02de5636f61c53bd16cf7e1d04625cb9646e2
Upgrade Splinter
0
432
627
626
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is an item found in {{BFF}} used to enhance [[weapons]] and [[armor]] to Mk 1, 2, and 3.
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found in the first big rectangular structure with pillars, near the [[Paladin Mace]]. Facing where the mace is, head right and past the red traffic light to find the item sitting on a ledge. || {{coords|-5173|-1105|5626}}
|}
{{Navbox/Items}}
[[Category:Upgrade items]]
b5014301a8a656873f94d981f8cd2ac3b7f1bbb7
Gingko Leaves
0
433
629
628
2025-08-21T18:10:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Materials|material]] found in {{BFF}} used in [[crafting]].
== Acquisition ==
Drops from several enemies in the game, as well as found on the ground in certain locations.
== Locations ==
{| class="wikitable"
! Amount !! Area !! Description !! Coordinates
|-
| 2 || [[Deluge]] || Found at the end of the platform before the bridge leading into the big rectangular structures with pillars. || {{coords|-4541|-1823|5552}}
|}
{{Navbox/Materials}}
[[Category:Materials]]
0fbff16a09a73af85c8ed1146f701144d7062005
Category:Items
14
434
631
2025-08-21T18:11:06Z
Sharparam
284703
Created page with "[[Items]] in {{BFF}}."
wikitext
text/x-wiki
[[Items]] in {{BFF}}.
16568f5641e17cc4807c868d51448584c4eee705
Homunculus Mirage Husk
0
435
632
2025-08-21T18:12:26Z
Sharparam
284703
Redirected page to [[Homunculus Mirage]]
wikitext
text/x-wiki
#REDIRECT [[Homunculus Mirage]]
4c51bab80fcbd9a41985179f691020f9d2813124
Unstable Perk Essence
0
436
633
2025-08-21T18:12:56Z
Sharparam
284703
Redirected page to [[Perk Essence]]
wikitext
text/x-wiki
#REDIRECT [[Perk Essence]]
e79a9129b7510dd8f427798b8611e23429960e63
Template:Navbox/Equipment
10
437
635
634
2025-08-21T18:16:06Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Equipment
| title = [[Equipment]]
| group1 = [[Weapons]]
| list1 = {{Navbox/Weapons|child}}
| group2 = [[Armor]]
| list2 = {{Navbox/Armor|child}}
| group3 = [[Amulets]]
| list3 = {{Navbox/Amulets|child}}
| group4 = [[Rings]]
| list4 = {{Navbox/Rings|child}}
| group5 = [[Capes]]
| list5 = {{Navbox/Capes|child}}
}}
4e9b09f139c8eefe809a3e0918f7584ff16eb363
644
635
2025-08-21T18:17:24Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Equipment
| title = [[Equipment]]
| group1 = [[Weapons]]
| list1 = {{Navbox/Weapons|child}}
| group2 = [[Armor]]
| list2 = {{Navbox/Armor|child}}
| group3 = [[Amulets]]
| list3 = {{Navbox/Amulets|child}}
| group4 = [[Rings]]
| list4 = {{Navbox/Rings|child}}
| group5 = [[Capes]]
| list5 = {{Navbox/Capes|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
73577a6e1a11270ffa35063d0266aa7a7766cf89
Template:Navbox/Weapons
10
438
637
636
2025-08-21T18:16:06Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<!-- Weapons must be listed in alphabetical order! -->
{{Navbox
| {{{1|}}}
| template = Navbox/Weapons
| title = [[Weapons]]
| group1 = [[One-handed weapons|One-handed]]
| list1 =
* [[Arming Sword]]
* [[Industrial Axe]]
* [[Industrial Mace]]
* [[Iron Pipe]]
* [[Longsword]]
* [[Machinist's Hammer]]
* [[Morning Star]]
* [[Paladin Mace]]
* [[Ratagan Sabre]]
* [[Scimitar]]
* [[Soul Breaker]]
* [[Tire Iron]]
* [[Torch]]
* [[Woodchopper]]
| group2 = [[Two-handed weapons|Two-handed]]
| list2 =
* [[Anastasia]]
* [[Claymore]]
* [[Faussart]]
* [[Halberd]]
* [[Mechanical Tenderizer]]
* [[Nodachi]]
* [[Royal Claymore]]
* [[Rusty Claymore]]
* [[Solaris]]
* [[Soul Reaper]]
* [[Valtiel]]
| group2.1 = [[Dual Wields]]
| list2.1 =
* [[Blades of Atropos]]
* [[Daggers]]
* [[Kamas]]
* [[Katanas]]
* [[Khopeshs]]
* [[Lacerators]]
| group2.2 = [[Twinblades]]
| list2.2 =
* [[Twinblade]]
| group2.3 = [[Greatweapons]]
| list2.3 =
* [[Armor Buster]]
* [[Divine Greataxe]]
* [[Eviscerator]]
* [[Greathammer]]
| group3 = [[Ranged weapons|Ranged]]
| group3.1 = [[Longbows]]
| list3.1 =
* [[Arcane Bow]]
* [[Longbow]]
* [[Taskmaster]]
* [[Winged bow]]
| group3.2 = [[Staves]]
| list3.2 =
* [[Asklepios]]
* [[Blessed Crosier]]
* [[Evolved Staff]]
* [[Mechanomad Staff]]
* [[Vermillion Staff]]
}}<noinclude>{{Documentation}}</noinclude>
441db50a6ddfe17d473822864f9d20f3a2af385f
645
637
2025-08-21T18:18:01Z
Sharparam
284703
Add category, remove documentation template
wikitext
text/x-wiki
<!-- Weapons must be listed in alphabetical order! -->
{{Navbox
| {{{1|}}}
| template = Navbox/Weapons
| title = [[Weapons]]
| group1 = [[One-handed weapons|One-handed]]
| list1 =
* [[Arming Sword]]
* [[Industrial Axe]]
* [[Industrial Mace]]
* [[Iron Pipe]]
* [[Longsword]]
* [[Machinist's Hammer]]
* [[Morning Star]]
* [[Paladin Mace]]
* [[Ratagan Sabre]]
* [[Scimitar]]
* [[Soul Breaker]]
* [[Tire Iron]]
* [[Torch]]
* [[Woodchopper]]
| group2 = [[Two-handed weapons|Two-handed]]
| list2 =
* [[Anastasia]]
* [[Claymore]]
* [[Faussart]]
* [[Halberd]]
* [[Mechanical Tenderizer]]
* [[Nodachi]]
* [[Royal Claymore]]
* [[Rusty Claymore]]
* [[Solaris]]
* [[Soul Reaper]]
* [[Valtiel]]
| group2.1 = [[Dual Wields]]
| list2.1 =
* [[Blades of Atropos]]
* [[Daggers]]
* [[Kamas]]
* [[Katanas]]
* [[Khopeshs]]
* [[Lacerators]]
| group2.2 = [[Twinblades]]
| list2.2 =
* [[Twinblade]]
| group2.3 = [[Greatweapons]]
| list2.3 =
* [[Armor Buster]]
* [[Divine Greataxe]]
* [[Eviscerator]]
* [[Greathammer]]
| group3 = [[Ranged weapons|Ranged]]
| group3.1 = [[Longbows]]
| list3.1 =
* [[Arcane Bow]]
* [[Longbow]]
* [[Taskmaster]]
* [[Winged bow]]
| group3.2 = [[Staves]]
| list3.2 =
* [[Asklepios]]
* [[Blessed Crosier]]
* [[Evolved Staff]]
* [[Mechanomad Staff]]
* [[Vermillion Staff]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
8e94326ebfefa20b4393ca4d4fc2a6076e02c41d
Template:Navbox/Armor
10
439
639
638
2025-08-21T18:16:06Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Crude Helmet]]
* [[Deserts Respirator Helmet]]
* [[Eris]]
* [[Librarian Hood]]
* [[Plagued Revenant Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Techpriest Helmet]]
| group2 = [[Pauldrons]]
| group3 = [[Chestguards]]
| list3 =
* [[Citadel Warrior Chest]]
* [[Corrupted Cuirass]]
* [[Librarian Overcoat]]
* [[Sentinel Chest]]
| group4 = [[Legguards]]
| list4 =
* [[Librarian Trousers]]
* [[Sentinel Legguard]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>{{Documentation}}</noinclude>
d47fdce5305e2ded83cd423d5b2674c32d0dde4d
646
639
2025-08-21T18:18:25Z
Sharparam
284703
Add category, remove documentation template
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Crude Helmet]]
* [[Deserts Respirator Helmet]]
* [[Eris]]
* [[Librarian Hood]]
* [[Plagued Revenant Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Techpriest Helmet]]
| group2 = [[Pauldrons]]
| group3 = [[Chestguards]]
| list3 =
* [[Citadel Warrior Chest]]
* [[Corrupted Cuirass]]
* [[Librarian Overcoat]]
* [[Sentinel Chest]]
| group4 = [[Legguards]]
| list4 =
* [[Librarian Trousers]]
* [[Sentinel Legguard]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
d68b49e449593d76c716ece8ba21c99d8eac2ea7
Template:Navbox/Shields
10
440
641
640
2025-08-21T18:16:06Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Shields
| title = [[Shields]]
| list1 =
* [[Flat Shield]]
* [[Kite Shield]]
* [[Military Shield]]
* [[Saracen Shield]]
* [[Spiked Shield]]
* [[Tall Military Shield]]
* [[Tech Shield]]
* [[Wooden Shield]]
}}
86b51292309060d7ff355bad7dc03a02f84ab69b
647
641
2025-08-21T18:18:48Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Shields
| title = [[Shields]]
| list1 =
* [[Flat Shield]]
* [[Kite Shield]]
* [[Military Shield]]
* [[Saracen Shield]]
* [[Spiked Shield]]
* [[Tall Military Shield]]
* [[Tech Shield]]
* [[Wooden Shield]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
104b8f0f103ef13f482417a9ededcf3a6c308f5a
Template:Navbox/Amulets
10
441
643
642
2025-08-21T18:16:07Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Amulets
| title = [[Amulets]]
| list1 =
* [[Amulet of Arcane Protection]]
* [[Amulet of Evasion]]
* [[Tactician's Amulet]]
}}
52e610bdb0cd1e26a433d4a731efea2e044132e1
648
643
2025-08-21T18:19:12Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Amulets
| title = [[Amulets]]
| list1 =
* [[Amulet of Arcane Protection]]
* [[Amulet of Evasion]]
* [[Tactician's Amulet]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
d43f33c31d7d77cfbae1cf4feb8facc7897d7b18
Rings
0
442
650
649
2025-08-21T18:20:39Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] that can be worn by the player to gain certain effects.
{{Navbox/Rings}}
[[Category:Rings]]
7adf2438732889de3ab3158748516564e3c337cb
Capes
0
443
652
651
2025-08-21T18:20:39Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] the player can wear to gain various bonus stats or effects.
{{Navbox/Capes}}
e68b383acdf3f302a6ce54944a3b34f545506c55
Amulets
0
444
654
653
2025-08-21T18:20:39Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox/Amulets}}
c49a050c320d9cc83e8ac20203557bb1adb26913
Shields
0
445
656
655
2025-08-21T18:20:39Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] that can be used to protect the player against incoming [[damage]].
{{Navbox/Shields}}
[[Category:Shields]]
1e7147da72fc96843c2350072a5e579292f4c0ac
Template:Navbox/Materials
10
446
657
2025-08-21T18:21:24Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Materials | title = [[Materials]] | list1= * [[Essence]] * [[Fractal Fungus]] * [[Gingko Leaves]] * [[Gravicle Dust]] * [[Machinite]] * [[Neurilium]] * [[Rustvine]] * [[Sludge]] * [[Spectral Ash]] }}<noinclude>[[Category:Navigation templates]]</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Materials
| title = [[Materials]]
| list1=
* [[Essence]]
* [[Fractal Fungus]]
* [[Gingko Leaves]]
* [[Gravicle Dust]]
* [[Machinite]]
* [[Neurilium]]
* [[Rustvine]]
* [[Sludge]]
* [[Spectral Ash]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
cd837e985ae9888fcc2a331afb915045b81932ff
Template:Armor/CargoDeclare
10
447
659
658
2025-08-21T18:35:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{#cargo_declare:_table=Armor
|name=String
|setname=String
|type=String
|weight=String
|sharpMk0=Integer
|bluntMk0=Integer
|technomancyMk0=Integer
|sharpMk1=Integer
|bluntMk1=Integer
|technomancyMk1=Integer
|sharpMk2=Integer
|bluntMk2=Integer
|technomancyMk2=Integer
|sharpMk3=Integer
|bluntMk3=Integer
|technomancyMk3=Integer
|sharpMk4=Integer
|bluntMk4=Integer
|technomancyMk4=Integer
|sharpMk5=Integer
|bluntMk5=Integer
|technomancyMk5=Integer
}}
338fa661fc066d90571ae8a2a2f747cb2c0d8f4f
Template:Weapons/CargoDeclare
10
448
661
660
2025-08-21T18:35:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{#cargo_declare:_table=Weapons
|name=String
|type=String
|speed=String
|damageType=String
|damageMk0Min=Integer
|damageMk0Max=Integer
|damageMk1Min=Integer
|damageMk1Max=Integer
|damageMk2Min=Integer
|damageMk2Max=Integer
|damageMk3Min=Integer
|damageMk3Max=Integer
|damageMk4Min=Integer
|damageMk4Max=Integer
|damageMk5Min=Integer
|damageMk5Max=Integer
}}
058226c206cdffeac8dd6c20fbd40d7a4b81f948
Template:Weapons/CargoStore
10
449
663
662
2025-08-21T18:35:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#cargo_store:_table=Weapons
|name={{{name|}}}
|type={{{type|}}}
|speed={{{speed|}}}
|damageType={{{damageType|}}}
|damageMk0Min={{{damageMk0Min|}}}
|damageMk0Max={{{damageMk0Max|}}}
|damageMk1Min={{{damageMk1Min|}}}
|damageMk1Max={{{damageMk1Max|}}}
|damageMk2Min={{{damageMk2Min|}}}
|damageMk2Max={{{damageMk2Max|}}}
|damageMk3Min={{{damageMk3Min|}}}
|damageMk3Max={{{damageMk3Max|}}}
|damageMk4Min={{{damageMk4Min|}}}
|damageMk4Max={{{damageMk4Max|}}}
|damageMk5Min={{{damageMk5Min|}}}
|damageMk5Max={{{damageMk5Max|}}}
}}</includeonly><noinclude>{{#cargo_attach:table=Weapons}}</noinclude>
f0f50597b71007312dd924dfdbdaec0c577db10f
Template:Armor/CargoStore
10
450
665
664
2025-08-21T18:35:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#cargo_store:_table=Armor
|name={{{name|}}}
|setname={{{setname|}}}
|type={{{type|}}}
|weight={{{weight|}}}
|sharpMk0={{{sharpMk0|}}}
|bluntMk0={{{bluntMk0|}}}
|technomancyMk0={{{technomancyMk0|}}}
|sharpMk1={{{sharpMk1|}}}
|bluntMk1={{{bluntMk1|}}}
|technomancyMk1={{{technomancyMk1|}}}
|sharpMk2={{{sharpMk2|}}}
|bluntMk2={{{bluntMk2|}}}
|technomancyMk2={{{technomancyMk2|}}}
|sharpMk3={{{sharpMk3|}}}
|bluntMk3={{{bluntMk3|}}}
|technomancyMk3={{{technomancyMk3|}}}
|sharpMk4={{{sharpMk4|}}}
|bluntMk4={{{bluntMk4|}}}
|technomancyMk4={{{technomancyMk4|}}}
|sharpMk5={{{sharpMk5|}}}
|bluntMk5={{{bluntMk5|}}}
|technomancyMk5={{{technomancyMk5|}}}
}}</includeonly><noinclude>{{#cargo_attach:table=Armor}}</noinclude>
333780ac478dc35967062b394838e177b662daa9
Template:Infobox/Weapon
10
451
667
666
2025-08-21T18:35:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| ranged = [[Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
6ed81445f4e99c129429ea030ff07667c32cc439
Template:Infobox/Weapon/doc
10
452
669
668
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for weapons",
"params": {
"title": {
"label": "Weapon name",
"description": "The name of the weapon",
"required": false,
"default": "{{PAGENAME}}",
"example": "Cool Sword",
"type": "string"
},
"image": {
"label": "Weapon image",
"description": "Name of the file used as the image for the weapon, should be at least 300 pixels wide.",
"required": true,
"example": "Cool weapon.png",
"type": "wiki-file-name"
},
"Type": {
"label": "Weapon type",
"description": "The type of the weapon.",
"required": true,
"example": "Dual Wields",
"type": "wiki-page-name"
},
"Speed": {
"label": "Weapon speed",
"description": "The speed category of the weapon.",
"required": true,
"example": "Fast",
"type": "string"
},
"Damage type": {
"label": "Weapon damage type",
"description": "The type of damage dealt by the weapon.",
"required": true,
"example": "Sharp",
"type": "wiki-page-name"
},
"Passives": {
"label": "Passive properties",
"description": "Any passive properties the weapon has, comma separated",
"required": false,
"example": "Health Regen, Flux Regen",
"type": "string"
},
"Abilities": {
"label": "Active abilities",
"description": "Active abilities that can be used when the weapon is equipped, comma separated",
"required": false,
"example": "Blade Dance",
"type": "string"
},
"Mk_min": {
"label": "Minimum mark level",
"description": "The initial mark level of the weapon",
"required": false,
"default": "0",
"example": "3",
"type": "number"
},
"Mk0_Damage_min": {
"label": "Min. damage at Mk. 0",
"description": "Minimum damage the weapon deals at Mk. 0",
"required": true,
"example": "5",
"type": "number"
},
"Mk0_Damage_max": {
"label": "Max. damage at Mk. 0",
"description": "Maximum damage the weapon deals at Mk. 0",
"required": true,
"example": "8",
"type": "number"
},
"Mk1_Damage_min": {
"label": "Min. damage at Mk. 1",
"description": "Minimum damage the weapon deals at Mk. 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Damage_max": {
"label": "Max. damage at Mk. 1",
"description": "Maximum damage the weapon deals at Mk. 1",
"required": true,
"example": "8",
"type": "number"
},
"Mk2_Damage_min": {
"label": "Min. damage at Mk. 2",
"description": "Minimum damage the weapon deals at Mk. 2",
"required": true,
"example": "10",
"type": "number"
},
"Mk2_Damage_max": {
"label": "Max. damage at Mk. 2",
"description": "Maximum damage the weapon deals at Mk. 2",
"required": true,
"example": "15",
"type": "number"
},
"Mk3_Damage_min": {
"label": "Min. damage at Mk. 3",
"description": "Minimum damage the weapon deals at Mk. 3",
"required": true,
"example": "20",
"type": "number"
},
"Mk3_Damage_max": {
"label": "Max. damage at Mk. 3",
"description": "Maximum damage the weapon deals at Mk. 3",
"required": true,
"example": "25",
"type": "number"
},
"Mk4_Damage_min": {
"label": "Min. damage at Mk. 4",
"description": "Minimum damage the weapon deals at Mk. 4",
"required": true,
"example": "30",
"type": "number"
},
"Mk4_Damage_max": {
"label": "Max. damage at Mk. 4",
"description": "Maximum damage the weapon deals at Mk. 4",
"required": true,
"example": "40",
"type": "number"
},
"Mk5_Damage_min": {
"label": "Min. damage at Mk. 5",
"description": "Minimum damage the weapon deals at Mk. 5",
"required": true,
"example": "50",
"type": "number"
},
"Mk5_Damage_max": {
"label": "Max. damage at Mk. 5",
"description": "Maximum damage the weapon deals at Mk. 5",
"required": true,
"example": "60",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Weapon
| title = Cool Sword
| image = Sword_01.svg
| Type = Dual Wields
| Speed = Fast
| Damage type = Sharp
| Passives = Infinite regen,Stuff,Cool
| Abilities = Blade Dance
| Mk_min = 1
| Mk1_Damage_min = 1
| Mk1_Damage_max = 2
| Mk2_Damage_min = 4
| Mk2_Damage_max = 6
| Mk3_Damage_min = 10
| Mk3_Damage_max = 12
| Mk4_Damage_min = 20
| Mk4_Damage_max = 25
| Mk5_Damage_min = 50
| Mk5_Damage_max = 60
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Weapon
| title = Cool Sword
| image = Sword_01.svg
| Type = Dual Wields
| Speed = Fast
| Damage type = Sharp
| Passives = Infinite regen
| Abilities = Blade Dance
| Mk_min = 1
| Mk1_Damage_min = 1
| Mk1_Damage_max = 2
| Mk2_Damage_min = 4
| Mk2_Damage_max = 6
| Mk3_Damage_min = 10
| Mk3_Damage_max = 12
| Mk4_Damage_min = 20
| Mk4_Damage_max = 25
| Mk5_Damage_min = 50
| Mk5_Damage_max = 60
}}
</syntaxhighlight>
03d55ce17e93a95147326d083a21a60c735a4602
Template:Infobox/Armor
10
453
671
670
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Weight,Set,Passives
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| helmet = [[Helmet]]
| pauldrons = [[Pauldrons]]
| chestguard = [[Chestguard]]
| legguard = [[Legguard]]
| gauntlet = [[Gauntlet]]
| #default = {{{Type}}}
}}}}
|Set={{#if:{{{Set|}}}|[[{{{Set}}}]]}}
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \!
| token = @@@@
| pattern = [[@@@@]]
| intro = \{\{hlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| helmet = [[Category:Helmets]]
| pauldrons = [[Category:Pauldrons]]
| chestguard = [[Category:Chestguards]]
| legguard = [[Category:Legguards]]
| gauntlet = [[Category:Gauntlets]]
| #default = [[Category:Armor]]
}}{{Armor/CargoStore
|name={{{title|}}}
|setname={{{Set|}}}
|type={{{Type|}}}
|weight={{{Weight|}}}
|sharpMk0={{{Mk0_Sharp|}}}
|bluntMk0={{{Mk0_Blunt|}}}
|technomancyMk0={{{Mk0_Technomancy|}}}
|sharpMk1={{{Mk1_Sharp|}}}
|bluntMk1={{{Mk1_Blunt|}}}
|technomancyMk1={{{Mk1_Technomancy|}}}
|sharpMk2={{{Mk2_Sharp|}}}
|bluntMk2={{{Mk2_Blunt|}}}
|technomancyMk2={{{Mk2_Technomancy|}}}
|sharpMk3={{{Mk3_Sharp|}}}
|bluntMk3={{{Mk3_Blunt|}}}
|technomancyMk3={{{Mk3_Technomancy|}}}
|sharpMk4={{{Mk4_Sharp|}}}
|bluntMk4={{{Mk4_Blunt|}}}
|technomancyMk4={{{Mk4_Technomancy|}}}
|sharpMk5={{{Mk5_Sharp|}}}
|bluntMk5={{{Mk5_Blunt|}}}
|technomancyMk5={{{Mk5_Technomancy|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
b1b6719714f0e3277010b8ca8d5ecb76f9538378
Template:Infobox/Armor/doc
10
454
673
672
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for armor",
"params": {
"image": {
"label": "Armor image",
"description": "Name of the file used as the image for the armor, should be at least 300 pixels wide.",
"required": true,
"example": "Cool armor.png",
"type": "wiki-file-name"
},
"Type": {
"label": "Armor type",
"description": "The type of armor.",
"required": true,
"example": "Helmet",
"type": "wiki-page-name"
},
"Weight": {
"label": "Armor weight",
"description": "The weight class of the armor.",
"required": true,
"example": "Light",
"type": "string"
},
"Set": {
"label": "Armor set",
"description": "Name of an armor set, if the piece is part of one.",
"required": false,
"example": "Cool set",
"type": "wiki-page-name"
},
"Passives": {
"label": "Passive effects",
"description": "Comma-separated list of passive effects",
"required": false,
"example": "Regen HP, Regen FX",
"type": "string"
},
"Mk1_Sharp": {
"label": "Mk 1 sharp rating",
"description": "Sharp defense rating at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Blunt": {
"label": "Mk 1 blunt rating",
"description": "Blunt defense rating at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Technomancy": {
"label": "Mk 1 technomancy rating",
"description": "Technomancy defense rating at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Sharp": {
"label": "Mk 2 sharp rating",
"description": "Sharp defense rating at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Blunt": {
"label": "Mk 2 blunt rating",
"description": "Blunt defense rating at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Technomancy": {
"label": "Mk 2 technomancy rating",
"description": "Technomancy defense rating at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Sharp": {
"label": "Mk 3 sharp rating",
"description": "Sharp defense rating at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Blunt": {
"label": "Mk 3 blunt rating",
"description": "Blunt defense rating at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Technomancy": {
"label": "Mk 3 technomancy rating",
"description": "Technomancy defense rating at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Sharp": {
"label": "Mk 4 sharp rating",
"description": "Sharp defense rating at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Blunt": {
"label": "Mk 4 blunt rating",
"description": "Blunt defense rating at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Technomancy": {
"label": "Mk 4 technomancy rating",
"description": "Technomancy defense rating at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Sharp": {
"label": "Mk 5 sharp rating",
"description": "Sharp defense rating at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Blunt": {
"label": "Mk 5 blunt rating",
"description": "Blunt defense rating at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Technomancy": {
"label": "Mk 5 technomancy rating",
"description": "Technomancy defense rating at Mk 5",
"required": true,
"example": "5",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Armor
| image = Helmet 2-1 SVG.svg
| title = Awesome helmet
| Type = Helmet
| Weight = Heavy
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Armor
| image = Helmet 2-1 SVG.svg
| title = Awesome helmet
| Type = Helmet
| Weight = Heavy
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
</syntaxhighlight>
03d97e9c6ffe6abdc853a4e886a5526e3ca4922d
Template:Infobox/Armor set
10
455
675
674
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor-set
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Pieces, Stats
|Basic Info=Weight
|Pieces=Helmet,Pauldrons,Chestguard,Legguard,Gauntlets
|Helmet={{#if:{{{Helmet|}}}|[[{{{Helmet}}}]]}}
|Pauldrons={{#if:{{{Pauldrons|}}}|[[{{{Pauldrons}}}]]}}
|Chestguard={{#if:{{{Chestguard|}}}|[[{{{Chestguard}}}]]}}
|Legguard={{#if:{{{Legguard|}}}|[[{{{Legguard}}}]]}}
|Gauntlets={{#if:{{{Gauntlets|}}}|[[{{{Gauntlets}}}]]}}
|tabs=
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||[[Category:Armor sets]]}}</includeonly><noinclude>
{{Documentation}}[[Category:Infobox templates]]</noinclude>
d0b44e9f72dec247f40dfa79c3541b37ed9c3937
Template:Infobox/Armor set/doc
10
456
677
676
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for an armor set",
"params": {
"image": {
"label": "Armor set image",
"description": "Name of the file used as the image for the armor set, should be at least 300 pixels wide.",
"required": true,
"example": "Cool armor set.png",
"type": "wiki-file-name"
},
"Weight": {
"label": "Armor set weight",
"description": "The weight class of the armor set.",
"required": true,
"example": "Light",
"type": "string"
},
"Helmet": {
"label": "Helmet piece",
"description": "The armor used for the helmet slot.",
"required": true,
"example": "Cool Helmet",
"type": "wiki-page-name"
},
"Pauldrons": {
"label": "Pauldrons piece",
"description": "The armor used for the pauldrons slot.",
"required": true,
"example": "Cool Pauldrons",
"type": "wiki-page-name"
},
"Chestguard": {
"label": "Chestguard piece",
"description": "The armor used for the chestguard slot.",
"required": true,
"example": "Cool Chestguard",
"type": "wiki-page-name"
},
"Legguard": {
"label": "Legguard piece",
"description": "The armor used for the legguard slot.",
"required": true,
"example": "Cool Legguard",
"type": "wiki-page-name"
},
"Gauntlets": {
"label": "Gauntlets piece",
"description": "The armor used for the gauntlets slot.",
"required": true,
"example": "Cool Gauntlets",
"type": "wiki-page-name"
},
"Mk1_Sharp": {
"label": "Mk 1 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Blunt": {
"label": "Mk 1 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Technomancy": {
"label": "Mk 1 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Sharp": {
"label": "Mk 2 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Blunt": {
"label": "Mk 2 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Technomancy": {
"label": "Mk 2 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Sharp": {
"label": "Mk 3 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Blunt": {
"label": "Mk 3 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Technomancy": {
"label": "Mk 3 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Sharp": {
"label": "Mk 4 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Blunt": {
"label": "Mk 4 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Technomancy": {
"label": "Mk 4 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Sharp": {
"label": "Mk 5 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Blunt": {
"label": "Mk 5 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Technomancy": {
"label": "Mk 5 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Armor set
| image = Awesome set.png
| title = Awesome set
| Weight = Heavy
| Helmet = Awesome Helmet
| Pauldrons = Awesome Pauldrons
| Chestguard = Awesome Chestguard
| Legguard = Awesome Legguard
| Gauntlets = Awesome Gauntlets
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Armor set
| image = Awesome set.png
| title = Awesome set
| Weight = Heavy
| Helmet = Awesome Helmet
| Pauldrons = Awesome Pauldrons
| Chestguard = Awesome Chestguard
| Legguard = Awesome Legguard
| Gauntlets = Awesome Gauntlets
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
</syntaxhighlight>
0b9b19ca76ed3cf82ad6c4644f7d39ea57f56907
Template:Infobox/Shield
10
457
679
678
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=shield
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Weight,Passives,Abilities
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{#if:{{{Mk0_Sharp|}}}|{{{Mk0_Sharp}}}%|???}}
|Mk0_Blunt={{#if:{{{Mk0_Blunt|}}}|{{{Mk0_Blunt}}}%|???}}
|Mk0_Technomancy={{#if:{{{Mk0_Technomancy|}}}|{{{Mk0_Technomancy}}}%|???}}
|Mk1_Sharp={{#if:{{{Mk1_Sharp|}}}|{{{Mk1_Sharp}}}%|???}}
|Mk1_Blunt={{#if:{{{Mk1_Blunt|}}}|{{{Mk1_Blunt}}}%|???}}
|Mk1_Technomancy={{#if:{{{Mk1_Technomancy|}}}|{{{Mk1_Technomancy}}}%|???}}
|Mk2_Sharp={{#if:{{{Mk2_Sharp|}}}|{{{Mk2_Sharp}}}%|???}}
|Mk2_Blunt={{#if:{{{Mk2_Blunt|}}}|{{{Mk2_Blunt}}}%|???}}
|Mk2_Technomancy={{#if:{{{Mk2_Technomancy|}}}|{{{Mk2_Technomancy}}}%|???}}
|Mk3_Sharp={{#if:{{{Mk3_Sharp|}}}|{{{Mk3_Sharp}}}%|???}}
|Mk3_Blunt={{#if:{{{Mk3_Blunt|}}}|{{{Mk3_Blunt}}}%|???}}
|Mk3_Technomancy={{#if:{{{Mk3_Technomancy|}}}|{{{Mk3_Technomancy}}}%|???}}
|Mk4_Sharp={{#if:{{{Mk4_Sharp|}}}|{{{Mk4_Sharp}}}%|???}}
|Mk4_Blunt={{#if:{{{Mk4_Blunt|}}}|{{{Mk4_Blunt}}}%|???}}
|Mk4_Technomancy={{#if:{{{Mk4_Technomancy|}}}|{{{Mk4_Technomancy}}}%|???}}
|Mk5_Sharp={{#if:{{{Mk5_Sharp|}}}|{{{Mk5_Sharp}}}%|???}}
|Mk5_Blunt={{#if:{{{Mk5_Blunt|}}}|{{{Mk5_Blunt}}}%|???}}
|Mk5_Technomancy={{#if:{{{Mk5_Technomancy|}}}|{{{Mk5_Technomancy}}}%|???}}
}}{{#if:{{NAMESPACE}}||[[Category:Shields]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
879802ba38814822053b519e3543784bf8a6ee64
Template:Infobox/Shield/doc
10
458
681
680
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Examples ==
{{Infobox/Shield
| image = Test shield.png
| title = Test Shield
| Weight = Light
| Abilities = Shield Bash
| Mk0_Sharp = 10
| Mk0_Blunt = 10
| Mk0_Technomancy = 10
| Mk1_Sharp = 20
| Mk1_Blunt = 20
| Mk1_Technomancy = 20
| Mk2_Sharp = 30
| Mk2_Blunt = 30
| Mk2_Technomancy = 30
| Mk3_Sharp = 40
| Mk3_Blunt = 40
| Mk3_Technomancy = 40
| Mk4_Sharp = 50
| Mk4_Blunt = 50
| Mk4_Technomancy = 50
| Mk5_Sharp = 60
| Mk5_Blunt = 60
| Mk5_Technomancy = 60
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Shield
| image = Test shield.png
| title = Test Shield
| Weight = Light
| Abilities = Shield Bash
| Mk0_Sharp = 10
| Mk0_Blunt = 10
| Mk0_Technomancy = 10
| Mk1_Sharp = 20
| Mk1_Blunt = 20
| Mk1_Technomancy = 20
| Mk2_Sharp = 30
| Mk2_Blunt = 30
| Mk2_Technomancy = 30
| Mk3_Sharp = 40
| Mk3_Blunt = 40
| Mk3_Technomancy = 40
| Mk4_Sharp = 50
| Mk4_Blunt = 50
| Mk4_Technomancy = 50
| Mk5_Sharp = 60
| Mk5_Blunt = 60
| Mk5_Technomancy = 60
}}
</syntaxhighlight>
f660f4831abeb203edfc85fcc8225afbe28becd3
Template:Infobox/Ability
10
459
683
682
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=ability
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info,Description
|Basic Info=Cost,Cooldown
|Cost_label=Flux cost
|Cooldown={{#if:{{{Cooldown|}}}|{{{Cooldown}}} seconds}}
|Description_nolabel=yes
|Description_isdata=yes
}}{{#if:{{NAMESPACE}}||[[Category:Abilities]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
c1ad1894018a724cf6235cea17b860aa85344fed
Template:Infobox/Ability/doc
10
460
685
684
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Example ==
{{Infobox/Ability
|image=SuperTux star-1.png
|title=Shoot Star
|Description=Shoots a star.
|Cost=50
|Cooldown=12
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Ability
|image=SuperTux star-1.png
|title=Shoot Star
|Description=Shoots a star.
|Cost=50
|Cooldown=12
}}
</syntaxhighlight>
c5af8361e58c9662fafe1e9ae1dfbc09ff0dedf9
Template:Infobox/Boss
10
461
687
686
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind = boss
| sep=,
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| title = {{{title|{{PAGENAME}}}}}
| sections = Basic Info, Stats
| Stats = HP, SharpResist, BluntResist, TechnomancyResist
| SharpResist_label = [[File:Sharp outlined.png|20px|link=Sharp]] [[Sharp]] resistance
| BluntResist_label = [[File:Blunt outlined.png|20px|link=Blunt]] [[Blunt]] resistance
| TechnomancyResist_label = [[File:Technomancy outlined.png|20px|link=Technomancy]] [[Technomancy]] resistance
| SharpResist = {{#if:{{{SharpResist|}}}|{{{SharpResist}}}%}}
| BluntResist = {{#if:{{{BluntResist|}}}|{{{BluntResist}}}%}}
| TechnomancyResist = {{#if:{{{TechnomancyResist|}}}|{{{TechnomancyResist}}}%}}
}}{{#if:{{NAMESPACE}}||[[Category:Bosses]]}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]
</noinclude>
64710a105198d7712f12bdaeab6e515bd71f2fe8
Template:Infobox/Cape
10
462
689
688
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=cape
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Effects
|Effects=Effect1,Effect2,Effect3
|Effect1_nolabel=yes
|Effect2_nolabel=yes
|Effect3_nolabel=yes
}}{{#if:{{NAMESPACE}}||[[Category:Capes]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
1957e3d416bf10a10bad93e51f649ad4f1768848
Template:Infobox/Cape/doc
10
463
691
690
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Examples ==
{{Infobox/Cape
| image = Cool cape.png
| title = Cool cape
| Effect1 = +50 coolness
| Effect2 = -1s cooldowns
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Cape
| image = Cool cape.png
| title = Cool cape
| Effect1 = +50 coolness
| Effect2 = -1s cooldowns
}}
</syntaxhighlight>
90d89e60cc634d47fd7681de76278937e16255fc
Template:Infobox/Item/doc
10
464
693
692
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Examples ==
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| Description = This item will do something fancy when you use it!
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| Description = This item will do something fancy when you use it!
}}
</syntaxhighlight>
9a956a5275f4ed54d4ffea9d646a5229cadc93a6
Weapons
0
465
695
694
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] in {{BFF}} used to engage in melee combat with [[enemies]].
== Upgrading ==
Weapons can be upgraded all the way to Mk 5 by speaking to [[The Handler]] and giving her the requisite materials.
Upgrading a weapon increases its damage as well as allowing you to embed more crystals into it to improve its properties further. Some weapons will also unlock passive bonuses or abilities when they are upgraded.
== List of weapons ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, CONCAT('[[', type, ']]')=Type, speed=Speed, CONCAT('[[', damageType, ']]')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk0Min, '{{!}}', damageMk0Max, '{{))}}')=Damage (Mk 0), CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|format=table
}}
{{Navbox/Weapons}}
627eeadeab2f527ee330ed3f5b806dcef85b45e8
Armor
0
466
697
696
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is protective [[equipment]] that can be worn to increase defensive stats.
== List of armor ==
{{#cargo_query:table=Armor
|fields=CONCAT('[[', name, ']]')=Name, CONCAT('[[', type, ']]')=Type, weight=Weight
|format=table
}}
{{Navbox/Armor}}
9bd135cf1860c6152460f40d36e8fe2636fd7ef3
Equipment
0
467
699
698
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] that the player can wear.
{{Navbox/Equipment}}
c2de744eb63e9dbba3e8fff73404a00624386c66
Category:Weapons
14
468
701
700
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''Weapons''' are equipment the player can use to damage monsters and defend themselves.
98e971be059993e01129097dd2602abe573ed443
Category:Dual Wields
14
469
703
702
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[Category:Weapons]]
febdf29cf9dcbef034e184720fe19a5ac5f353d8
Divine Greataxe
0
470
705
704
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Divine Greataxe.png
| Type = Greatweapon
| Damage type = Sharp
| Speed = Sluggish
| Passives = Greater Divine Judgment
| Abilities = Regal Radiance
| Mk4_Damage_min = 597
| Mk4_Damage_max = 656
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
== Location ==
{{coords|43210.37|165132.67|-141105.39}}
Found in the [[Anomaly]]. From the [[Homunculus]], walk past [[The Handler]] and you will see the item up ahead on the ledge of a building.
{{Navbox/Weapons}}
0ae771a14e6b5fd5c63e8a73b5aebd90154e8bff
Category:Chestguards
14
471
707
706
2025-08-21T18:35:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[Category:Armor]]
8dbf198b5dcaa87a18100850cc78880444b773ad
Dual Wield
0
472
709
708
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Stub}}
'''{{PAGENAME}}''' is a [[Weapons|weapon]] type in {{BFF}}.
== List of Dual Wields ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, speed=Speed, CONCAT('[[', damageType, ']]')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|where=type='Dual Wield'
|format=table
}}
[[Category:Dual Wields]]
6c2224d2e50f2da2b16a52ca04227ca57d27bbc8
Dual wield
0
473
711
710
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[Dual Wield]]
f2856295451ab1cd2a686e19d6b0fbaa265f1d98
Dual Wields
0
474
713
712
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[Dual Wield]]
f2856295451ab1cd2a686e19d6b0fbaa265f1d98
Katanas
0
475
715
714
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Katanas.png
| Type = Dual Wield
| Speed = Fast
| Damage type = Sharp
| Abilities = Blade Dash, Whirlwind Strike
| Mk3_Damage_min = 117
| Mk3_Damage_max = 130
| Mk4_Damage_min = 165
| Mk4_Damage_max = 183
| Mk5_Damage_min = 235
| Mk5_Damage_max = 261
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
Available as a drop from [[enemies]] in [[Uranopolis#Tower Complex|Uranopolis (Tower Complex)]].
{{Navbox/Weapons}}
4ab46d81614502ef87bbdcd436c9621993e809bd
Kamas
0
476
717
716
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Kamas.png
| Type = Dual Wield
| Speed = Swift
| Damage type = Sharp
| Passives = Powerful Decay
| Abilities = Bladestorm
| Mk3_Damage_min = 112
| Mk3_Damage_max = 130
| Mk4_Damage_min = 269
| Mk4_Damage_max = 313
| Mk5_Damage_min = 308
| Mk5_Damage_max = 358
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
{{Navbox/Weapons}}
80fd6cf0dc6a59c85d7b761b05ed0b0cb9908c27
Lacerators
0
477
719
718
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Lacerators.png
| Type = Dual Wield
| Speed = Fast
| Damage type = Sharp
| Passives = Lacerate, Lifesteal
| Mk2_Damage_min = 97
| Mk2_Damage_max = 108
| Mk5_Damage_min = 235
| Mk5_Damage_max = 261
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
{{Navbox/Weapons}}
b1946670af3fe4f2bd09c0dfc86872b327a200a9
Daggers
0
478
721
720
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Daggers.png
| Type = Dual Wield
| Speed = Swift
| Damage type = Sharp
| Abilities = Dual Brutality, Shadowstep
| Mk_min = 2
| Mk2_Damage_min = 106
| Mk2_Damage_max = 123
| Mk3_Damage_min = 135
| Mk3_Damage_max = 157
}}
'''{{PAGENAME}}''' are a type of [[dual wield]] [[Weapons|weapon]] in {{BFF}}.
== Location ==
Located together with the [[sentinel]] [[Armor sets|armor set]] on a corpse in [[Asylum|the asylum]]. See [[Sentinel#Location]] for its location.
{{Navbox/Weapons}}
564b414d6a096a1107d0569379379434b1e1f48e
Khopeshs
0
479
723
722
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Khopeshs.png
| Type = Dual Wield
| Damage type = Sharp
| Speed = Fast
| Abilities = Dual Brutality, Bladestorm
| Mk0_Damage_min = 92
| Mk0_Damage_max = 102
| Mk1_Damage_min = 104
| Mk1_Damage_max = 115
| Mk2_Damage_min = 115
| Mk2_Damage_max = 128
| Mk3_Damage_min = 139
| Mk3_Damage_max = 154
}}
'''{{PAGENAME}}''' are a type of [[Dual Wield]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
Dropped by [[Plagued Nemesis]].
{{Navbox/Weapons}}
c8f5f702bd2d22af0adff4ad34825ffb25021210
Blades of Atropos
0
480
725
724
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Blades of Atropos.png
| Type = Dual Wield
| Damage type = Sharp
| Speed = Fast
| Passives = Bloodthirst
| Abilities = Phase
| Mk0_Damage_min = 131
| Mk0_Damage_max = 145
| Mk1_Damage_min = 147
| Mk1_Damage_max = 164
| Mk2_Damage_min = 164
| Mk2_Damage_max = 182
| Mk3_Damage_min = 197
| Mk3_Damage_max = 218
| Mk4_Damage_min = 229
| Mk4_Damage_max = 255
| Mk5_Damage_min = 262
| Mk5_Damage_max = 291
}}
'''{{PAGENAME}}''' are a [[Dual Wields|dual wield]] weapon in {{BFF}}.
== Location ==
{{coords|2778|-6115|-1198}}
Found in [[Desert Mirage]]. Just down the stairs from the [[Homunculus]].
{{Navbox/Weapons}}
52da0a005c0bcb26cb17a6ee2da89b32c687e4ea
Citadel Warrior Chest
0
481
727
726
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| image = Citadel Warrior Chest.png
| title = {{PAGENAME}}
| Type = Chestguard
| Weight = Medium
| Set = Citadel Warrior
| Mk2_Sharp = 984
| Mk2_Blunt = 1296
| Mk2_Technomancy = 719
}}
{{Navbox/Armor}}
2d3a3133daf3387abf5d098ec92e1514330b81d4
Librarian Overcoat
0
482
729
728
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| image = Librarian Overcoat.png
| title = {{PAGENAME}}
| Type = Chestguard
| Set = Librarian
| Weight = Light
| Mk1_Sharp = 660
| Mk1_Blunt = 744
| Mk1_Technomancy = 1009
}}
== Location ==
Dropped by "Librarian" enemies in [[Deluge|the Deluge]]?
{{Navbox/Armor}}
ae4dc71e0b3fd31a0a4477632675eea80c6965d8
Corrupted Cuirass
0
483
731
730
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| image = Corrupted Cuirass.png
| title = {{PAGENAME}}
| Type = Chestguard
| Weight = Heavy
| Mk2_Sharp = 1728
| Mk2_Blunt = 1488
| Mk2_Technomancy = 174
}}
{{Navbox/Armor}}
183dddf62f3fe9d1345ac172c6970d381d73782b
Citadel Warrior
0
484
733
732
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor set
| image = Citadel Warrior.png
| title = {{PAGENAME}}
| Weight = Medium
| Helmet = Citadel Warrior Helmet
| Pauldrons = Citadel Warrior Shoulders
| Chestguard = Citadel Warrior Chest
| Legguard = Citadel Warrior Legguards
| Gauntlets = Citadel Warrior Gauntlets
}}
'''{{PAGENAME}}''' is an [[armor set]] in {{BFF}}.
== Pieces ==
* [[Citadel Warrior Helmet]]
* [[Citadel Warrior Shoulders]]
* [[Citadel Warrior Chest]]
* [[Citadel Warrior Legguards]]
* [[Citadel Warrior Gauntlets]]
== See also ==
* [[Citadel Defender]] – Heavy variant with higher defense ratings.
{{Navbox/Armor}}
e1f48b76a2706b1879b8a99de8adffee44fc8785
Sentinel
0
485
735
734
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor set
| image = Sentinel.png
| title = {{PAGENAME}}
| Helmet = Sentinel Helmet
| Chestguard = Sentinel Chest
| Legguard = Sentinel Legguard
| Gauntlets = Sentinel Gauntlets
}}
'''{{PAGENAME}}''' is an [[Armor sets|armor set]] that can be found in {{BFF}}.
== Location ==
{{coords|-3634|1305|9617}}
The full set can be found on a corpse in [[Asylum|the Asylum]]. After reaching the top of the small spiral staircase, continue through the long corridor and get to the bottom of the next room. Walk through the doorway and hug the left wall to reach an area behind a wall with a corpse sitting in a corner holding the armor set and the [[Daggers]].
{{Navbox/Armor}}
c383d5b5ea00cce79216ed8915d5810d12cb993f
Vengeance
0
486
737
736
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor set
| title = {{PAGENAME}}
| image = Vengeance.png
| Helmet = Vengeance Helmet
| Chestguard = Vengeance Cuirass
| Legguard = Vengeance Legs
| Gauntlets = Vengeance Gauntlets
}}
'''{{PAGENAME}}''' is an [[Armor sets|armor set]] found in {{BFF}}.
== Location ==
{{coords|-3925|1676|9471}}
Found on a corpse in the shortcut area leading to the big tower.
{{Navbox/Armor}}
37e805d19347a1c48db878ae9dc7e86a5905fb7b
Librarian (armor set)
0
487
739
738
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor set
| image = Librarian.png
| title = Librarian
| Weight = Light
| Helmet = Librarian Hood
| Pauldrons = <!-- Librarian ??? -->
| Chestguard = Librarian Overcoat
| Legguard = Librarian Trousers
| Gauntlets = <!-- Librarian ??? -->
}}
'''Librarian''' is an [[armor set]] in {{BFF}}.
== Pieces ==
* [[Librarian Hood]]
<!-- * [[Librarian ???]] -->
* [[Librarian Overcoat]]
* [[Librarian Trousers]]
<!-- * [[Librarian ???]] -->
{{Navbox/Armor}}
ad355bf6137087d645f4fbb2ac96e384f57db8a8
Librarian Trousers
0
488
741
740
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| image = Librarian Trousers.png
| title = {{PAGENAME}}
| Type = Legguard
| Weight = Light
| Set = Librarian
| Mk1_Sharp = 456
| Mk1_Blunt = 516
| Mk1_Technomancy = 696
}}
{{Navbox/Armor}}
1d0c2fa9e238497ee92524a75f41846d76113cd8
Crude Helmet
0
489
743
742
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| image = Crude Helmet.png
| title = {{PAGENAME}}
| Type = Helmet
| Weight = Medium
| Mk2_Sharp = 516
| Mk2_Blunt = 600
| Mk2_Technomancy = 336
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] type of [[armor]] that can be found in {{BFF}}.
== Location ==
{{coords|-3538|-6027|5477}}
Found in [[Deluge|the Deluge]] area. After reaching the bottom of the big broken tower (where [[Folk Cape]] and [[Dust Sea|the Dust Sea]] can be found), continue right and follow the wall until you see a a corpse on a ledge holding the item.
{{Navbox/Armor}}
4327414a895ebc5fd2ac98909457618e6423b0f3
Skullface Helmet
0
490
745
744
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Skullface Helmet.png
| Type = Helmet
| Weight = Light
| Passives = [[Volatile Illusions]]
| Mk5_Sharp = 692
| Mk5_Blunt = 692
| Mk5_Technomancy = 928
}}
== Location ==
{{coords|-4063|1564|1686}}
After reaching the room with a big circular elevator in the middle, look around the edges of the room for a bookshelf containing the helmet.
{{Navbox/Armor}}
06db38be9569d6ea522dedf56d2264708ad17817
Techpriest Helmet
0
491
747
746
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Techpriest Helmet.png
| Type = Helmet
| Weight = Light
| Passives = [[Minor Flux Regen]]
| Mk5_Sharp = 722
| Mk5_Blunt = 722
| Mk5_Technomancy = 928
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|1272|-8495|551}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], head through the doorway and take the left path. After reaching the outdoors area, head up the stairs and take a narrow path on the right leading to a small area behind a building with the helmet in a corner.
{{Navbox/Armor}}
a7a7b23c199012fb916ce23130908fb2796a023c
Deserts Respirator Helmet
0
492
749
748
2025-08-21T18:35:43Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Deserts Respirator Helmet.png
| Type = helmet
| Weight = Medium
| Mk2_Sharp = 545
| Mk2_Blunt = 633
| Mk2_Technomancy = 336
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|1367|6630|-1395}}
Found in the [[Desert]]. Located on a corpse near the portal to [[Desert Mirage]].
{{Navbox/Armor}}
85a4c5a22cdde742f764acd2e76c15d11d03503d
Plagued Revenant Helmet
0
493
751
750
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Plagued Revenant Helmet.png
| Type = Helmet
| Weight = Medium
| Mk5_Sharp = 883
| Mk5_Blunt = 1024
| Mk5_Technomancy = 540
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Acquisition ==
Drops from [[Plagued Revenant]].
{{Navbox/Armor}}
dcf20306f52ebb49a60617476143ab6a73580f6b
Librarian Hood
0
494
753
752
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Librarian Hood.png
| Type = Helmet
| Weight = Light
| Set = Librarian
| Mk1_Sharp = 371
| Mk1_Blunt = 371
| Mk1_Technomancy = 469
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Acquisition ==
Drops from [[Librarian (enemy)|librarian]] enemies.
{{Navbox/Armor}}
524d688d52e40e59b69ca9f6a46e4f593a6fcdab
Eris
0
495
755
754
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Eris.png
| Type = Helmet
| Weight = Light
| Passives = Flux Efficiency
| Mk5_Sharp = 730
| Mk5_Blunt = 730
| Mk5_Technomancy = 939
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|2860|-4261|1423}}
Found in [[Uranopolis#Tower Complex|Uranopolis (Tower Complex)]]. Nestled between some round pillars.
{{Navbox/Armor}}
3716b6c0ca03c71f6dc10ebb3357cb49aa6862ef
One-handed weapons
0
496
757
756
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[Weapons|weapon]] in {{BFF}} that come in two variants: [[sharp]] and [[blunt]].
== List of one-handed weapons ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, speed=Speed, CONCAT('[[', damageType, ']]')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk0Min, '{{!}}', damageMk0Max, '{{))}}')=Damage (Mk 0), CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|where=type='one-handed'
|format=table
}}
{{Navbox/Weapons}}
[[Category:One-handed weapons]]
db05c537c888c3ecd32676dae4cbd9e3b79033c3
Paladin Mace
0
497
759
758
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| image = Paladin Mace.png
| title = {{PAGENAME}}
| Type = one-handed
| Damage type = Blunt
| Speed = Fast
| Abilities = Divine Blessing
| Mk0_Damage_min = 76
| Mk0_Damage_max = 83
| Mk1_Damage_min = 85
| Mk1_Damage_max = 93
| Mk2_Damage_min = 95
| Mk2_Damage_max = 104
}}
'''{{PAGENAME}}''' is a [[One-handed weapons|one-handed]] [[Weapons|weapon]] that can be found in {{BFF}}.
== Location ==
{{coords|-4879|-7530|5578}}
In [[Deluge|the Deluge]]. Located in a square hole in the wall inside the first rectangular structure with pillars after crossing a bridge. The [[Items|item]] can be seen straight ahead when crossing the bridge.
{{Navbox/Weapons}}
9ae9ef12f0012f7ee76e8b19eb462a731a31721f
Scimitar
0
498
761
760
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Scimitar.png
| Type = One-handed
| Damage type = Sharp
| Speed = Swift
| Abilities = Whiplash
| Mk2_Damage_min = 150
| Mk2_Damage_max = 163
}}
'''{{PAGENAME}}''' is a [[One-handed weapons|one-handed weapon]] in {{BFF}}.
== Location ==
{{coords|1713|7517|-1413}}
Located inside a building in the [[Desert]], after getting down on the bottom.
{{Navbox/Weapons}}
7da5444707df0750219ed6dda415a75ee3b04a8e
Nodachi
0
499
763
762
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Nodachi.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Whirlwind, Tornado
| Mk3_Damage_min = 315
| Mk3_Damage_max = 344
| Mk4_Damage_min = 368
| Mk4_Damage_max = 402
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Acquisition ==
Dropped by [[Nurgei the Blademaster]].
{{Navbox/Weapons}}
86417f91f727b87f778da76948fb454da2e92744
Soul Reaper
0
500
765
764
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Soul Reaper.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Reap, Soul Storm
| Mk3_Damage_min = 322
| Mk3_Damage_max = 361
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Location ==
{{coords|1413|-9293|190}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. When reaching the outdoors area, head up the stairs and go left. Climb up the cliff by repeatedly tapping the jump button. Once at the top, head forward and follow the path that leads downwards. Eventually you will reach a group of buildings. In front of one of these is the weapon.
{{Navbox/Weapons}}
950b71e0fc9d4dbdefdb52a2c58ee43849dd7600
Anastasia
0
501
767
766
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Anastasia.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Reanimate Dead, Silencing Reap
| Mk3_Damage_min = 364
| Mk3_Damage_max = 408
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Acquisition ==
Drops from [[Plagued Revenant]].
{{Navbox/Weapons}}
999c96e5d8b0e959b4174e16951f4d2f08e6598c
Crescent Axe
0
502
769
768
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Crescent Axe.png
| Type = two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Expose Armor, Crescent Slash
| Mk2_Damage_min = 251
| Mk2_Damage_max = 271
}}
== Location ==
{{coords|-3932|1535|1532}}
Located in the room with [[The Banshee]] [[Data logs|data log]].
6ae8e711635fe9f28bf31f5f61c2b8a34e8e0452
Royal Claymore
0
503
771
770
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Royal Claymore.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Claymore Swing, Sword Strike
| Mk3_Damage_min = 315
| Mk3_Damage_max = 344
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Location ==
{{coords|-9938|7939|-1340}}
Found in [[Desert|the Desert]]. Starting where the [[Shifting Sands]] data log can be found, climb up the stairs on either side and walk through the arch. The item can be seen across a gap. Do a jump while sprinting to cross the gap and reach the item.
{{Navbox/Weapons}}
d8f571fe32e600c12e02d6d3d5e06dac9e5df229
Valtiel
0
504
773
772
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Valtiel.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Syphon Life, Carnage
| Mk3_Damage_min = 522
| Mk3_Damage_max = 562
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Acquisition ==
Drops from [[Vermillion Knight|Vermillion Knights]].
{{Navbox/Weapons}}
cd2852971f9cc25db419ef806fb9c0960f845d16
Twinblade
0
505
775
774
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Twinblade.png
| Type = Twinblade
| Damage type = Sharp
| Speed = Swift
| Abilities = Blade Dance, Blade Flurry
| Mk3_Damage_min = 75
| Mk3_Damage_max = 78
}}
'''{{PAGENAME}}''' is a [[Twinblades|twinblade]] [[Weapons|weapon]] in {{BFF}}.
== Acquisition ==
Drops from [[enemies]] using the twinblade weapon.
{{Navbox/Weapons}}
f75786b2c8e5d234ef871b2f5c2e32b4924b1b6a
Asklepios
0
506
777
776
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Asklepios.png
| Type = Staff
| Damage type = Technomancy
| Speed = Slow
| Abilities = Mending Light, Second Breath
| Mk3_Damage_min = 117
| Mk3_Damage_max = 120
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] weapon in {{BFF}}.
== Acquisition ==
Dropped by big floating knights with blue lightsabers in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]].
{{Navbox/Weapons}}
19d3bc07174d18e309f111ea29df123b354aac8e
Vermillion Staff
0
507
779
778
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Vermillion Staff.png
| Type = Staff
| Damage type = Technomancy
| Speed = Slow
| Abilities = Forceful Repulsion, Quake
| Mk_min = 3
| Mk3_Damage_min = 117
| Mk3_Damage_max = 120
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] weapon in {{BFF}}.
== Location ==
{{coords|1241|-8256|275}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], go through the doorway and take the left path. At the outdoor area with a big staircase leading up, head instead to the right before the staircase, leading to an area with some tombstones. The weapon can be found leaning against a wall in the dead-end.
{{Navbox/Weapons}}
e59fb090f56eced502c56a092f5d2cf9267c2818
Blessed Crosier
0
508
781
780
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Blessed Crosier.png
| Type = Staff
| Damage type = Technomancy
| Speed = Slow
| Abilities = Escape Velocity, Energy Burst
| Mk3_Damage_min = 173
| Mk3_Damage_max = 177
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}.
== Acquisition ==
Dropped by [[Archinquisitor Belisarius (boss)]].
{{Navbox/Weapons}}
d1d557ec6a9700fda1ee5579a6f5c4cf86cd912f
Arcane Bow
0
509
783
782
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Arcane Bow.png
| Type = Ranged
| Damage type = Sharp
| Speed = Fast
| Passives = Vermillion Judgment
| Abilities = Arrow Twister
| Mk2_Damage_min = 184
| Mk2_Damage_max = 197
| Mk3_Damage_min = 251
| Mk3_Damage_max = 267
| Mk4_Damage_min = 292
| Mk4_Damage_max = 312
| Mk5_Damage_min = 334
| Mk5_Damage_max = 356
}}
'''{{PAGENAME}}''' is a [[Bows|bow]] in {{BFF}}.
== Location ==
{{coords|1261|-8400|1563}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the left path. When in the outdoors area, head into the path on the right before the big stairs. Take the ladder at the end getting up onto a building, and then the next one. The item will be in the corner of the roof on a corpse.
{{Navbox/Weapons}}
9ed7d6da9990d1b86ae941adf6cc8ea5f6b173fb
Taskmaster
0
510
785
784
2025-08-21T18:35:44Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Taskmaster.png
| Type = Ranged
| Damage type = Sharp
| Speed = Fast
| Passives = Rapid Fire, Critical Strike
| Mk2_Damage_min = 240
| Mk2_Damage_max = 256
}}
'''{{PAGENAME}}''' is a [[Ranged weapons|ranged weapon]] in {{BFF}}.
== Location ==
{{coord|4052|1265|-1412}}
Located in the [[Desert]]. After meeting [[Yaroslav|Yaroslav's]] crew and passing through the passage to the big open area, look slightly to the left and you'll see the bow resting against some run down brick arches.
{{Navbox/Weapons}}
dd37cc2a86e75e6fa9d8f0c27f5bfcb3c3a09e92
Category:Pages declaring Cargo tables
14
511
786
2025-08-21T18:36:35Z
Sharparam
284703
Created blank page
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
Wanderer Cape
0
512
788
787
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Cape
| title = {{PAGENAME}}
| image = Wanderer Cape.png
| Effect1 = -0.5 second delay before stamina starts to regenerate.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] that can be worn in {{BFF}}.
{{Navbox/Capes}}
1f5137f1dafe59cd4ffe5c3b254751901918d15e
Folk Cape
0
513
790
789
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Cape
| image = Folk Cape.png
| title = {{PAGENAME}}
| Effect1 = -20% Technocasting speed
| Effect2 = +10% [[Technomancy]] penetration
| Effect3 = +50 Max [[flux]] points
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] that can be worn by the player to gain certain effects.
== Location ==
{{coords|-3979|-2143|5796}}
At the top of a broken down tower in [[Deluge|the Deluge]] area, in front of [[Dust Sea|the Dust Sea]] [[Data logs|data log]]. After reaching the first [[homunculus]] of the area, walk up the stairs (past [[The Handler]]) and head left, then continue until you enter the big tower. Climb the tower to the top and you'll find the item on the ground at the top of the last set of stairs.
{{Navbox/Capes}}
ced1f8221d9ad9bf30775a81e257aa3efb4d12dd
Corrupted Cape
0
514
792
791
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Cape
| image = Corrupted Cape.png
| title = {{PAGENAME}}
| Effect1 = +800 [[Sharp]] armor rating.
| Effect2 = +800 [[Blunt]] armor rating.
| Effect3 = +800 [[Technomancy]] armor rating.
}}
== Location ==
Dropped by the bigger knight guys ("Corrupted"?) wearing halberts in [[Deluge]].
{{Navbox/Capes}}
85092d24492b81865456f0c2ec6b4b43f2e6c927
Techpriest Cape
0
515
794
793
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Cape
| image = Techpriest Cape
| title = {{PAGENAME}}
| Effect1 = +50 Max [[flux]] points.
| Effect2 = +150 [[Flux]] leech rating.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}} that can be worn by the player.
== Location ==
{{coords|-4527|8973|9614}}
Found in [[Asylum]]. After entering the first courtyard, climb the stairs on the right and jump onto the right ledge, then follow it backwards (towards the direction you entered from) and the item will be on a corpse on the left.
== Trivia ==
* "Techpriest" in the name might be a reference to [https://wh40k.lexicanum.com/wiki/Tech-priest tech-priests] from [[w:Warhammer 40,000|Warhammer 40,000]].
{{Navbox/Capes}}
a7524062d33903459d69f5c7ae482dff8f0536c9
Amulet of Arcane Protection
0
516
796
795
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Amulet of Arcane Protection.png
| Passives = [[Techno-Defiance]]
| Effect1 = +1500 [[Technomancy]] armor rating.
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Location ==
{{coords|4158|-2902|1459}}
Found near the top side of a shortcut ladder in [[Uranopolis]].
{{Navbox/Amulets}}
18efef3d358787360eb91c39568ddbe8822cdf47
Amulet of Evasion
0
517
798
797
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Amulet of Evasion.png
| Passives = [[Extended Evasion]]
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Location ==
{{coords|1251|-8419|551}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], go through the doorway and take the left path. When at the outdoors area, take the big stairs up and head immediately right, then to the wall and the item will be in a corner on the right, behind a building.
{{Navbox/Amulets}}
9e21e16f6b5f152489ca325ce8295f57ce37b702
Tactician's Amulet
0
518
800
799
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Tactician's Amulet.png
| Effects = Removes invincibility frames
| Passives = Vulnerable Dodge
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
{{Navbox/Amulets}}
8032681e4f4e42a1fa5445d736a503ae40145d42
Ring of Burning Desire
0
519
802
801
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ring
| image = Ring of Burning Desire.png
| title = {{PAGENAME}}
| Effect1 = +20% chance to inflict [[heat]] [[status effect]].
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] that can be found in {{BFF}}.
== Acquisition ==
Drops from [[Diver]] [[enemies]] in [[Deluge|the Deluge]] area.
{{Navbox/Rings}}
e25c13f86a914c3c38145e3c207d7ca4d045bcf0
Ring of Casting Speed
0
520
804
803
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Casting Speed.png
| Effect1 = -10% attack power.
| Effect2 = +20% technocasting speed.
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Acquisition ==
Drops from a giant enemy in [[Uranopolis]], around {{coords|-1151|-4475|1453}}.
{{Navbox/Rings}}
46f3eb13e5516b422e23a89fb5ec0e0a924ed783
Ring of Rammstein
0
521
806
805
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Rammstein.png
| Passives = [[Momentum Strike]]
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Location ==
{{main|Tech Shield#Location}}
This item is located on the same corpse as the [[Tech Shield]].
{{Navbox/Rings}}
1bf2ae52125b19a63277c4ea076e1cf3f2107e6e
Ring of Exceeding Talent
0
522
808
807
2025-08-21T18:40:01Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Exceeding Talent.png
| Effect1 = +3 [[Strength]]
| Effect2 = +3 [[Agility]]
| Effect3 = +3 [[Constitution]]
| Effect4 = +3 [[Intelligence]]
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Location ==
{{coords|3720|1159|-1397}}
Located in the [[Desert]] on a toppled pillar in the area with Yaroslav's crew (same location as the [[Handler Echo]]).
== See also ==
* [[Ring of Lesser Talent]] – The weakest version of this ring.
* [[Ring of Talent]] – A weaker version of this ring.
{{Navbox/Rings}}
bcbe61aaf34441d0c94fadf4e2d02dbe42c66205
Category:Rings
14
523
809
2025-08-21T18:40:49Z
Sharparam
284703
Created page with "[[Rings]] in {{BFF}}. [[Category:Equipment]]"
wikitext
text/x-wiki
[[Rings]] in {{BFF}}.
[[Category:Equipment]]
6be38d49249074ddfca4ec380e09f5762403fd47
Category:Equipment
14
524
810
2025-08-21T18:41:11Z
Sharparam
284703
Created page with "[[Equipment]] in {{BFF}}. [[Category:Items]]"
wikitext
text/x-wiki
[[Equipment]] in {{BFF}}.
[[Category:Items]]
15110e4ea1647cf4d9e255a1263386500041dfd3
Category:Pages using invalid arguments in ParserPower functions
14
525
811
2025-08-21T18:43:02Z
Sharparam
284703
Created page with "__HIDDENCAT__ __EXPECTUNUSEDCATEGORY__"
wikitext
text/x-wiki
__HIDDENCAT__
__EXPECTUNUSEDCATEGORY__
7e6b7092e497df1715b699132e1d441f8d47d5ff
Sharp
0
526
813
812
2025-08-21T18:43:57Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''Sharp''' is a type of damage in {{BFF}}.
791f7c953da43e2ac6ebe338f36d863e32d3ac49
Template:Average/doc
10
532
824
2025-08-21T18:48:54Z
Sharparam
284703
Remove unused doc templates
wikitext
text/x-wiki
This template is used to find the average (default mean) of a series of numbers.
==Parameters==
Parameters with a number as the value are the numbers to find the average of.
==Examples==
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|100000000}}</syntaxhighlight> → {{Average|10|20|30|40|100000000}}
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|50|100000000}}</syntaxhighlight> → {{Average|10|20|30|40|50|100000000}}
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|50|100000000|round=2}}</syntaxhighlight> → {{Average|10|20|30|40|50|100000000|round=2}}
==See also==
*{{tl|Median}}
9ec70adff5359cd4d4afdfa0d6d5d8f24974fc11
825
824
2025-08-21T18:49:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
This template is used to find the average (default mean) of a series of numbers.
==Parameters==
Parameters with a number as the value are the numbers to find the average of.
==Examples==
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|100000000}}</syntaxhighlight> → {{Average|10|20|30|40|100000000}}
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|50|100000000}}</syntaxhighlight> → {{Average|10|20|30|40|50|100000000}}
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|50|100000000|round=2}}</syntaxhighlight> → {{Average|10|20|30|40|50|100000000|round=2}}
==See also==
*{{tl|Median}}
9ec70adff5359cd4d4afdfa0d6d5d8f24974fc11
Template:DamageRange
10
527
815
814
2025-08-21T18:49:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{Tooltip|{{{1}}}–{{{2}}}|Average: {{Average|{{{1}}}|{{{2}}}}}}}{{#if:{{{type|}}}| {{#switch:{{lc:{{{type}}}}}
| sharp = [[Sharp]]
| blunt = [[Blunt]]
| tech
| technomancy = [[Technomancy]]
| #default = {{{type}}}
}}|}}</includeonly><noinclude>{{Documentation}}</noinclude>
bee05e8ca021e7585fc203ed68db91f82ab057e2
Template:DamageRange/doc
10
528
817
816
2025-08-21T18:49:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|10|20}}</syntaxhighlight> → {{DamageRange|10|20}}
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|1|2}}</syntaxhighlight> → {{DamageRange|1|2}}
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|69|75|type=sharp}}</syntaxhighlight> → {{DamageRange|69|75|type=sharp}}
a5a6c8376c27ec92e876a4bf84571a621dfedbac
Template:Tooltip
10
529
819
818
2025-08-21T18:49:41Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<templatestyles src="Template:Tooltip/styles.css" /><includeonly><span class="tooltip tooltip-dotted" title="{{#replace:{{{2}}}|"|"}}">{{{1}}}</span></includeonly><noinclude>
{{Documentation|Template:Abbr/doc}}
</noinclude>
02939f9a947fe3904add1355d50d42b05211f8b9
Template:Tooltip/styles.css
10
530
821
820
2025-08-21T18:49:42Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
.tooltip-dotted {
border-bottom: 1px dotted;
}
.tooltip-help {
cursor: help;
}
af2f58c266b5958cf73537f523615e9783db80ff
Template:Average
10
531
823
822
2025-08-21T18:49:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#if:{{{round|}}}|{{formatnum:{{round|{{#invoke:math|average}}|{{{round|}}}}}|R}}|{{#invoke:math|average}}}}</includeonly><noinclude>{{doc}}</noinclude>
b37093608b62a3faf722c64135fc79c4498e3d5b
Template:Abbr/doc
10
533
827
826
2025-08-21T18:49:42Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Examples ==
=== [[Template:Tooltip]] ===
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text|tooltip title}}</syntaxhighlight> → {{Tooltip|text|tooltip title}}
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text "with" quotes|tooltip "with" quotes}}</syntaxhighlight> → {{Tooltip|text "with" quotes|tooltip "with" quotes}}
7e8e0dc4e38c09167b11915c2ddced76bbfe4ae4
Module:Math
828
534
829
828
2025-08-21T18:49:42Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
--[[
This module provides a number of basic mathematical operations.
]]
local yesno, getArgs -- lazily initialized
local p = {} -- Holds functions to be returned from #invoke, and functions to make available to other Lua modules.
local wrap = {} -- Holds wrapper functions that process arguments from #invoke. These act as intemediary between functions meant for #invoke and functions meant for Lua.
--[[
Helper functions used to avoid redundant code.
]]
local function err(msg)
-- Generates wikitext error messages.
return mw.ustring.format('<strong class="error">Formatting error: %s</strong>', msg)
end
local function unpackNumberArgs(args)
-- Returns an unpacked list of arguments specified with numerical keys.
local ret = {}
for k, v in pairs(args) do
if type(k) == 'number' then
table.insert(ret, v)
end
end
return unpack(ret)
end
local function makeArgArray(...)
-- Makes an array of arguments from a list of arguments that might include nils.
local args = {...} -- Table of arguments. It might contain nils or non-number values, so we can't use ipairs.
local nums = {} -- Stores the numbers of valid numerical arguments.
local ret = {}
for k, v in pairs(args) do
v = p._cleanNumber(v)
if v then
nums[#nums + 1] = k
args[k] = v
end
end
table.sort(nums)
for i, num in ipairs(nums) do
ret[#ret + 1] = args[num]
end
return ret
end
local function fold(func, ...)
-- Use a function on all supplied arguments, and return the result. The function must accept two numbers as parameters,
-- and must return a number as an output. This number is then supplied as input to the next function call.
local vals = makeArgArray(...)
local count = #vals -- The number of valid arguments
if count == 0 then return
-- Exit if we have no valid args, otherwise removing the first arg would cause an error.
nil, 0
end
local ret = table.remove(vals, 1)
for _, val in ipairs(vals) do
ret = func(ret, val)
end
return ret, count
end
--[[
Fold arguments by selectively choosing values (func should return when to choose the current "dominant" value).
]]
local function binary_fold(func, ...)
local value = fold((function(a, b) if func(a, b) then return a else return b end end), ...)
return value
end
--[[
random
Generate a random number
Usage:
{{#invoke: Math | random }}
{{#invoke: Math | random | maximum value }}
{{#invoke: Math | random | minimum value | maximum value }}
]]
function wrap.random(args)
local first = p._cleanNumber(args[1])
local second = p._cleanNumber(args[2])
return p._random(first, second)
end
function p._random(first, second)
math.randomseed(mw.site.stats.edits + mw.site.stats.pages + os.time() + math.floor(os.clock() * 1000000000))
-- math.random will throw an error if given an explicit nil parameter, so we need to use if statements to check the params.
if first and second then
if first <= second then -- math.random doesn't allow the first number to be greater than the second.
return math.random(first, second)
end
elseif first then
return math.random(first)
else
return math.random()
end
end
--[[
order
Determine order of magnitude of a number
Usage:
{{#invoke: Math | order | value }}
]]
function wrap.order(args)
local input_string = (args[1] or args.x or '0');
local input_number = p._cleanNumber(input_string);
if input_number == nil then
return err('order of magnitude input appears non-numeric')
else
return p._order(input_number)
end
end
function p._order(x)
if x == 0 then return 0 end
return math.floor(math.log10(math.abs(x)))
end
--[[
precision
Detemines the precision of a number using the string representation
Usage:
{{ #invoke: Math | precision | value }}
]]
function wrap.precision(args)
local input_string = (args[1] or args.x or '0');
local trap_fraction = args.check_fraction;
local input_number;
if not yesno then
yesno = require('Module:Yesno')
end
if yesno(trap_fraction, true) then -- Returns true for all input except nil, false, "no", "n", "0" and a few others. See [[Module:Yesno]].
local pos = string.find(input_string, '/', 1, true);
if pos ~= nil then
if string.find(input_string, '/', pos + 1, true) == nil then
local denominator = string.sub(input_string, pos+1, -1);
local denom_value = tonumber(denominator);
if denom_value ~= nil then
return math.log10(denom_value);
end
end
end
end
input_number, input_string = p._cleanNumber(input_string);
if input_string == nil then
return err('precision input appears non-numeric')
else
return p._precision(input_string)
end
end
function p._precision(x)
if type(x) == 'number' then
x = tostring(x)
end
x = string.upper(x)
local decimal = x:find('%.')
local exponent_pos = x:find('E')
local result = 0;
if exponent_pos ~= nil then
local exponent = string.sub(x, exponent_pos + 1)
x = string.sub(x, 1, exponent_pos - 1)
result = result - tonumber(exponent)
end
if decimal ~= nil then
result = result + string.len(x) - decimal
return result
end
local pos = string.len(x);
while x:byte(pos) == string.byte('0') do
pos = pos - 1
result = result - 1
if pos <= 0 then
return 0
end
end
return result
end
--[[
max
Finds the maximum argument
Usage:
{{#invoke:Math| max | value1 | value2 | ... }}
Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.max(args)
return p._max(unpackNumberArgs(args))
end
function p._max(...)
local max_value = binary_fold((function(a, b) return a > b end), ...)
if max_value then
return max_value
end
end
--[[
median
Find the median of set of numbers
Usage:
{{#invoke:Math | median | number1 | number2 | ...}}
OR
{{#invoke:Math | median }}
]]
function wrap.median(args)
return p._median(unpackNumberArgs(args))
end
function p._median(...)
local vals = makeArgArray(...)
local count = #vals
table.sort(vals)
if count == 0 then
return 0
end
if p._mod(count, 2) == 0 then
return (vals[count/2] + vals[count/2+1])/2
else
return vals[math.ceil(count/2)]
end
end
--[[
min
Finds the minimum argument
Usage:
{{#invoke:Math| min | value1 | value2 | ... }}
OR
{{#invoke:Math| min }}
When used with no arguments, it takes its input from the parent
frame. Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.min(args)
return p._min(unpackNumberArgs(args))
end
function p._min(...)
local min_value = binary_fold((function(a, b) return a < b end), ...)
if min_value then
return min_value
end
end
--[[
sum
Finds the sum
Usage:
{{#invoke:Math| sum | value1 | value2 | ... }}
OR
{{#invoke:Math| sum }}
Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.sum(args)
return p._sum(unpackNumberArgs(args))
end
function p._sum(...)
local sums, count = fold((function(a, b) return a + b end), ...)
if not sums then
return 0
else
return sums
end
end
--[[
average
Finds the average
Usage:
{{#invoke:Math| average | value1 | value2 | ... }}
OR
{{#invoke:Math| average }}
Note, any values that do not evaluate to numbers are ignored.
]]
function wrap.average(args)
return p._average(unpackNumberArgs(args))
end
function p._average(...)
local sum, count = fold((function(a, b) return a + b end), ...)
if not sum then
return 0
else
return sum / count
end
end
--[[
round
Rounds a number to specified precision
Usage:
{{#invoke:Math | round | value | precision }}
--]]
function wrap.round(args)
local value = p._cleanNumber(args[1] or args.value or 0)
local precision = p._cleanNumber(args[2] or args.precision or 0)
if value == nil or precision == nil then
return err('round input appears non-numeric')
else
return p._round(value, precision)
end
end
function p._round(value, precision)
local rescale = math.pow(10, precision or 0);
return math.floor(value * rescale + 0.5) / rescale;
end
--[[
log10
returns the log (base 10) of a number
Usage:
{{#invoke:Math | log10 | x }}
]]
function wrap.log10(args)
return math.log10(args[1])
end
--[[
mod
Implements the modulo operator
Usage:
{{#invoke:Math | mod | x | y }}
--]]
function wrap.mod(args)
local x = p._cleanNumber(args[1])
local y = p._cleanNumber(args[2])
if not x then
return err('first argument to mod appears non-numeric')
elseif not y then
return err('second argument to mod appears non-numeric')
else
return p._mod(x, y)
end
end
function p._mod(x, y)
local ret = x % y
if not (0 <= ret and ret < y) then
ret = 0
end
return ret
end
--[[
gcd
Calculates the greatest common divisor of multiple numbers
Usage:
{{#invoke:Math | gcd | value 1 | value 2 | value 3 | ... }}
--]]
function wrap.gcd(args)
return p._gcd(unpackNumberArgs(args))
end
function p._gcd(...)
local function findGcd(a, b)
local r = b
local oldr = a
while r ~= 0 do
local quotient = math.floor(oldr / r)
oldr, r = r, oldr - quotient * r
end
if oldr < 0 then
oldr = oldr * -1
end
return oldr
end
local result, count = fold(findGcd, ...)
return result
end
--[[
precision_format
Rounds a number to the specified precision and formats according to rules
originally used for {{template:Rnd}}. Output is a string.
Usage:
{{#invoke: Math | precision_format | number | precision }}
]]
function wrap.precision_format(args)
local value_string = args[1] or 0
local precision = args[2] or 0
return p._precision_format(value_string, precision)
end
function p._precision_format(value_string, precision)
-- For access to Mediawiki built-in formatter.
local lang = mw.getContentLanguage();
local value
value, value_string = p._cleanNumber(value_string)
precision = p._cleanNumber(precision)
-- Check for non-numeric input
if value == nil or precision == nil then
return err('invalid input when rounding')
end
local current_precision = p._precision(value)
local order = p._order(value)
-- Due to round-off effects it is neccesary to limit the returned precision under
-- some circumstances because the terminal digits will be inaccurately reported.
if order + precision >= 14 then
if order + p._precision(value_string) >= 14 then
precision = 13 - order;
end
end
-- If rounding off, truncate extra digits
if precision < current_precision then
value = p._round(value, precision)
current_precision = p._precision(value)
end
local formatted_num = lang:formatNum(math.abs(value))
local sign
-- Use proper unary minus sign rather than ASCII default
if value < 0 then
sign = '−'
else
sign = ''
end
-- Handle cases requiring scientific notation
if string.find(formatted_num, 'E', 1, true) ~= nil or math.abs(order) >= 9 then
value = value * math.pow(10, -order)
current_precision = current_precision + order
precision = precision + order
formatted_num = lang:formatNum(math.abs(value))
else
order = 0;
end
formatted_num = sign .. formatted_num
-- Pad with zeros, if needed
if current_precision < precision then
local padding
if current_precision <= 0 then
if precision > 0 then
local zero_sep = lang:formatNum(1.1)
formatted_num = formatted_num .. zero_sep:sub(2,2)
padding = precision
if padding > 20 then
padding = 20
end
formatted_num = formatted_num .. string.rep('0', padding)
end
else
padding = precision - current_precision
if padding > 20 then
padding = 20
end
formatted_num = formatted_num .. string.rep('0', padding)
end
end
-- Add exponential notation, if necessary.
if order ~= 0 then
-- Use proper unary minus sign rather than ASCII default
if order < 0 then
order = '−' .. lang:formatNum(math.abs(order))
else
order = lang:formatNum(order)
end
formatted_num = formatted_num .. '<span style="margin:0 .15em 0 .25em">×</span>10<sup>' .. order .. '</sup>'
end
return formatted_num
end
--[[
divide
Implements the division operator
Usage:
{{#invoke:Math | divide | x | y | round= | precision= }}
--]]
function wrap.divide(args)
local x = args[1]
local y = args[2]
local round = args.round
local precision = args.precision
if not yesno then
yesno = require('Module:Yesno')
end
return p._divide(x, y, yesno(round), precision)
end
function p._divide(x, y, round, precision)
if y == nil or y == "" then
return err("Empty divisor")
elseif not tonumber(y) then
if type(y) == 'string' and string.sub(y, 1, 1) == '<' then
return y
else
return err("Not a number: " .. y)
end
elseif x == nil or x == "" then
return err("Empty dividend")
elseif not tonumber(x) then
if type(x) == 'string' and string.sub(x, 1, 1) == '<' then
return x
else
return err("Not a number: " .. x)
end
else
local z = x / y
if round then
return p._round(z, 0)
elseif precision then
return p._round(z, precision)
else
return z
end
end
end
--[[
Helper function that interprets the input numerically. If the
input does not appear to be a number, attempts evaluating it as
a parser functions expression.
]]
function p._cleanNumber(number_string)
if type(number_string) == 'number' then
-- We were passed a number, so we don't need to do any processing.
return number_string, tostring(number_string)
elseif type(number_string) ~= 'string' or not number_string:find('%S') then
-- We were passed a non-string or a blank string, so exit.
return nil, nil;
end
-- Attempt basic conversion
local number = tonumber(number_string)
-- If failed, attempt to evaluate input as an expression
if number == nil then
local success, result = pcall(mw.ext.ParserFunctions.expr, number_string)
if success then
number = tonumber(result)
number_string = tostring(number)
else
number = nil
number_string = nil
end
else
number_string = number_string:match("^%s*(.-)%s*$") -- String is valid but may contain padding, clean it.
number_string = number_string:match("^%+(.*)$") or number_string -- Trim any leading + signs.
if number_string:find('^%-?0[xX]') then
-- Number is using 0xnnn notation to indicate base 16; use the number that Lua detected instead.
number_string = tostring(number)
end
end
return number, number_string
end
--[[
Wrapper function that does basic argument processing. This ensures that all functions from #invoke can use either the current
frame or the parent frame, and it also trims whitespace for all arguments and removes blank arguments.
]]
local mt = { __index = function(t, k)
return function(frame)
if not getArgs then
getArgs = require('Module:Arguments').getArgs
end
return wrap[k](getArgs(frame)) -- Argument processing is left to Module:Arguments. Whitespace is trimmed and blank arguments are removed.
end
end }
return setmetatable(p, mt)
2bbe734d898299f65412963a3c1782e9fcc4d9ca
Template:Plainlist
10
535
831
830
2025-08-21T18:51:17Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<templatestyles src="Plainlist/styles.css"/><div class="plainlist {{{class|}}}" {{safesubst<noinclude />:#if:{{{style|}}}{{{indent|}}}|style="{{safesubst<noinclude />:#if:{{{indent|}}}|margin-left: {{safesubst<noinclude />:#expr:{{{indent}}}*1.6}}em;}} {{{style|}}}"}}>{{safesubst<noinclude />:#if:{{{1|}}}|
{{{1}}}
</div>}}<noinclude></div>
{{documentation}}
</noinclude>
1f83cec6d8a2e5ba45342d554089a71b19afae80
Template:Plainlist/styles.css
10
536
833
832
2025-08-21T18:51:17Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
.plainlist ol,
.plainlist ul {
line-height: inherit;
list-style: none;
margin: 0;
padding: 0; /* Reset Minerva default */
}
.plainlist ol li,
.plainlist ul li {
margin-bottom: 0;
}
15a09febff47c3fa7ff01092a7cd381b44a14427
Template:Navbox/Enemies
10
538
836
2025-08-21T18:53:26Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Enemies
| title = [[Enemies]]
| list1 =
* [[Berserking Citizen]]
* [[Citizen]]
* [[Construction Golem]]
* [[Deranged]]
* [[Dreadguard]]
* [[Fisherman]]
* [[Lancer]]
* [[Mechanomad Technomancer]]
* [[Mechanomad Warrior]]
* [[Minotaur]]
* [[Mrgud]]
* [[Osteoclast]]
* [[Plagued]]
* [[Revenant]]
* [[Vermillion Knight]]
* [[Zealot]]
| group2 = [[Bosses]]
| list2 = {{Navbox/Bosses|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
24cfff4a2c251e67dc47c1f176a54be03c2b71a5
837
836
2025-08-21T18:54:09Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Enemies
| title = [[Enemies]]
| list1 =
* [[Berserking Citizen]]
* [[Citizen]]
* [[Construction Golem]]
* [[Deranged]]
* [[Dreadguard]]
* [[Fisherman]]
* [[Lancer]]
* [[Mechanomad Technomancer]]
* [[Mechanomad Warrior]]
* [[Minotaur]]
* [[Mrgud]]
* [[Osteoclast]]
* [[Plagued]]
* [[Revenant]]
* [[Vermillion Knight]]
* [[Zealot]]
| group2 = [[Bosses]]
| list2 = {{Navbox/Bosses|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
24cfff4a2c251e67dc47c1f176a54be03c2b71a5
Enemies
0
537
835
834
2025-08-21T18:54:09Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Navbox/Enemies}}
833889e0d1b529dbf02a0a7b4ded350913eaaadd
Bosses
0
539
839
838
2025-08-21T18:54:09Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful, unique [[enemies]] that do not respawn and typically grant bigger rewards when defeated.
{{Navbox/Bosses}}
0c3e8dc2475799e24d9fb25b0d80bf435d40e02a
Category:Bosses
14
540
841
840
2025-08-21T18:54:09Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[Category:Enemies]]
d3da306a1b523dea15853a2b661da0200bf2f201
868
841
2025-08-21T18:56:28Z
Sharparam
284703
Add description
wikitext
text/x-wiki
[[Bosses]] in {{BFF}}.
[[Category:Enemies]]
f6372fb3755dcaa25f58460244200cff259ffce0
Fisherman
0
541
843
842
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is an enemy in {{BFF}} that appears in the [[Deluge]] location.
== Drops ==
* [[Diver's Lungs Concoction]]
* [[Fractal Fungus]]
* [[Gingko Leaves]]
* [[Lesser Anomalous Crystal]]
* [[Lesser Restorative Fluid]]
* [[Ring of Burning Desire]]
* [[Sludge]]
* [[Upgrade Splinter]]
[[Category:Enemies]]
854a2903c300d816cf3a65b85c7bee9c7c9aeb6e
Plagued Nemesis
0
542
845
844
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| image = Plagued Nemesis.png
| SharpResist = 32
| BluntResist = 2
| TechnomancyResist = 50
}}
'''{{PAGENAME}}''' is an optional [[boss]] [[Enemies|enemy]] in {{BFF}}.
== Location ==
Found at the top of the big tower in [[Asylum|the asylum]].
== Drops ==
* [[Khopeshs]]
* [[Unstable Perk Essence]]
* [[Upgrade Module]]
* [[Anomalous Fragment]] (Only in [[NG+]])
{{Navbox/Bosses}}
3ab22950bbea5ef8c5c7eecf9db701cacb0006a0
Silicon Visage
0
543
847
846
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| image = Silicon Visage.png
| SharpResist = 15
| BluntResist = 16
| TechnomancyResist = 55
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] [[Enemies|enemy]] in {{BFF}}.
== Location ==
{{coords|9307|2902|1628}} (approximate)
Located in [[Upper Blocks]].
== Drops ==
* [[Upgrade Module]]
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
773d7fa0e470181a1ad1ada63a49044d0679caf7
Nurgei the Blademaster
0
544
849
848
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Nurgei the Blademaster.png
| SharpResist = 29
| BluntResist = 37
| TechnomancyResist = 57
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] [[Enemies|enemy]] in {{BFF}}.
== Location ==
{{coords|1138|-9288|1571}} (approximate)
Found in [[Uranopolis#Lone Tower|Uranopolis (Lone Tower)]]. From the [[Homunculus]], walk across the long bridge lined with pillars and you will see him straight ahead in his boss arena.
== Drops ==
* [[Upgrade Module]]
* [[Nodachi]]
* [[Unstable Perk Essence]]
* [[Anomalous Fragment]] ([[NG+]])
{{Navbox/Bosses}}
1f8634a99af6d189e90d0e6283c284736ffbd4fe
Plagued Warden
0
545
851
850
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Plagued Warden.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|2395|-2410|529}} (approximate)
Located in [[Blok 6147]]. After getting off the [[subway]], take the path leading up and then take the stairs on the left. You will see a platform nearby with a spiked shield on the far end. Interacting with the shield spawns the boss, but doing so requires having the [[Plagued Blood]] item in your inventory.
== Drops ==
* [[Spiked Shield]] (only in NG (or if you don't yet have it?))
* [[Anomalous Fragment]] (only in [[NG+]] (or if you don't have the shield?))
{{Navbox/Bosses}}
5dfd44f48ae568136e010129ccbd00bbd7c71a55
Plagued Revenant
0
546
853
852
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Plagued Revenant.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|1432|-8866|199}} (approximate)
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. After getting to the outdoors area, keep going straight until you get to the end, take a right and then left to get down to a cliff area. Go left and you'll see a mausoleum inside the cliff on the left with some graves in front of it. In front of the doors of this mausoleum is a helmet ({{coords|1409|-8884|190}}). Interacting with the helmet to attempt to take it will spawn the boss behind you.
== Drops ==
* [[Anastasia]]
* [[Plagued Revenant Helmet]]
== Trivia ==
* When dying to this boss, crying can be heard during the loading screen. This could either be intentional or a result of the nearby crying enemy respawning.
{{Navbox/Bosses}}
698530510328c2e5031366f6586a3eb9494a65e4
Wormlord
0
547
855
854
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Wormlord.png
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Overview ==
Defeating Wormlord is required to be able to access [[The Anomaly]].
== Location ==
{{coords|2550|-4122|-1198}} (approximate)
Found in [[Desert Mirage]]. The entire area is dedicated as its boss arena.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
aedb9551379ee1f1febb972b361a1b8ee9e1c3fd
Archinquisitor Belisarius (boss)
0
548
857
856
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{About|the [[Bosses|boss]]|the [[NPC]]|Archinquisitor Belisarius}}
{{Infobox/Boss
| title = Archinquisitor Belisarius
| image = Archinquisitor Belisarius (boss).png
}}
'''Archinquisitor Belisarius''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|4315|1734|-1413}} (approximate)
Found at the beginning of the [[Anomaly]] area.
== Drops ==
* [[Blessed Crosier]]
* [[Unstable Perk Essence]]
* [[Upgrade Module]]
== Quotes ==
=== Upon engaging him ===
{{Quote
|Well well… You made it through. As much as I hate to elevate your spiteful existence to the height of the truth… this is where we are now.
Ever since you've joined us, all you've done is fulfil the goals of the disgusting administration you work for.
The mundane pursuit of tasks is all you know… and this crusade against that apostate filth at the gate is just a backdrop to your performance.
Yet [[Anomaly|the anomaly]] is a blessing I will not let slip out of my hands… for it is instrumental in aiding the God-Emperor, noble is he and eternal, to finally transcend.
Nothing will stand in that path, I assure you. Not the Serdars, not [[Yaroslav]] and definitely not you – a dog that obeys by reflex instead of will.
Now… we both know you never quite die – so you'll at least find out what an eternity of pain is made of. Good thing you have no name – those make for the best martyrs.
}}
{{Navbox/Bosses}}
73a24d629934b27f74f10c58c9ab9e02ed3858bc
Unknown (boss)
0
549
859
858
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{About|the [[Bosses|boss]]|the [[Locations|location]]|Unknown (location)}}
{{Infobox/Boss
| title = Unknown
| image = Unknown (boss).png
}}
'''Unknown''' is an optional [[Bosses|boss]] in {{BFF}}.
== Overview ==
The Unknown resembles the player character in [[armor]], but uses its own [[Weapons|weapon]] instead of mirroring the player's. It does not drop its weapon on defeat.
Upon defeating the boss, the player is immediately transported to [[Vermillion Fields]].
== Location ==
Located at the end of the [[Unknown (location)|Unknown]], being the boss of the area.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
08cbc1e8f1d754f6cc8e5e04d59cc388bc187d8f
Konrad the Traitor
0
550
861
860
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Konrad the Traitor.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}.
== Overview ==
The boss is not mandatory for progression, as the [[Old Key]] can be looted off the ground behind him. However, skipping him means not having access to [[Homunculus Mirage]], as the husk drops from him (including in [[NG+]]).
== Location ==
{{coords|18794.39|-40662.96|-15.20}} (approximate)
Located at the top of the [[Monastery]], being the area's boss.
== Drops ==
* [[Homunculus Mirage Husk]]
* [[Handler Echo]]
* [[Anomalous Fragment]] ([[NG+]])
{{Navbox/Bosses}}
acd47fd792b54614f8d3d42a80fe9037a65997cc
Royal Division Captain Yulia & Vermillion Mirage
0
551
863
862
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| image = Final boss.png
}}
'''{{PAGENAME}}''' is the final [[Bosses|boss]] in {{BFF}}.
== Overview ==
When starting the fight, only the [[Vermillion Mirage]] will be present, including showing only its name in the boss healthbar.
After the mirage takes a certain amount of damage, [[Royal Division Captain Yulia]] will join the fight, updating the name in the boss healthbar to include both of them.
Dying for any reason after Yulia joins the fight causes the player to gain 0.5% [[entropy]]. This is because the act of her joining applies a debuff to the player causing entropy gain on death.
Throughout the fight, they will take turns being the active enemy, with the other one falling back to take a more passive role and using various ranged abilities on the player.
Defeating the boss will immediately trigger the [[Endings|ending]] cutscene.
After getting back to the title screen, the save file can be loaded again which will put the player at the same homunculus, allowing for the boss to be fought again. This makes it the only boss in the game that can be fought multiple times without having to start a new game.
== Location ==
Found at the end of [[Vermillion Fields]]. At the final location of the "Temple" [[Homunculus]], head up the large stairs and the boss arena will be at the top.
{{Navbox/Bosses}}
[[Category:Pages that need coordinates]]
dfff03fcfd660a270e379514af4cb192c6e3d589
Mutated Ghoul
0
552
865
864
2025-08-21T18:54:10Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Boss
| image = Mutated Ghoul.png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}.
== Location ==
{{coords|6937.36|-64861.39|-17736.47}} (approximate)
Located in a big grass field at the bottom of the [[Monastery]].
== Drops ==
* [[Anomalous Fragment]] (only in [[NG+]])
{{Navbox/Bosses}}
8e88bd012af5d51d364d79af5fc33127dd67fa4d
Template:Navbox/Bosses
10
553
866
2025-08-21T18:55:01Z
Sharparam
284703
Created page with "<!-- List bosses in alphabetical order -->{{Navbox | {{{1|}}} | template = Navbox/Bosses | title = [[Bosses]] | list1 = * [[Aberrant Knight]] * [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]] * [[Konrad the Traitor]] * [[Mutated Ghoul]] * [[Nurgei the Blademaster]] * [[Plagued Nemesis]] * [[Plagued Revenant]] * [[Plagued Warden]] * [[Royal Division Captain Yulia & Vermillion Mirage]] * [[Silicon Visage]] * [[Unknown (boss)|Unknown]] * [[Wormlord]] }}<noinc..."
wikitext
text/x-wiki
<!-- List bosses in alphabetical order
-->{{Navbox
| {{{1|}}}
| template = Navbox/Bosses
| title = [[Bosses]]
| list1 =
* [[Aberrant Knight]]
* [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]]
* [[Konrad the Traitor]]
* [[Mutated Ghoul]]
* [[Nurgei the Blademaster]]
* [[Plagued Nemesis]]
* [[Plagued Revenant]]
* [[Plagued Warden]]
* [[Royal Division Captain Yulia & Vermillion Mirage]]
* [[Silicon Visage]]
* [[Unknown (boss)|Unknown]]
* [[Wormlord]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
e281c4190fb60fa20447ad931105d10e630d08b7
Bosses
0
539
867
839
2025-08-21T18:55:55Z
Sharparam
284703
Add category
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful, unique [[enemies]] that do not respawn and typically grant bigger rewards when defeated.
{{Navbox/Bosses}}
[[Category:Bosses]]
bb7b42c9d701b6e1db772a7bcd242b850128fe27
Category:Enemies
14
554
869
2025-08-21T18:57:13Z
Sharparam
284703
Created page with "[[Enemies]] in {{BFF}}."
wikitext
text/x-wiki
[[Enemies]] in {{BFF}}.
112bd8e00bed6ea82522cac44012b082f89bb6d9
Enemies
0
537
870
835
2025-08-21T18:58:04Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox/Enemies}}
[[Category:Enemies]]
d6faf8074e8ca5dfe61e1d61bd2b3e81348c1ba8
Category:Capes
14
555
871
2025-08-21T19:55:58Z
Sharparam
284703
Created page with "[[Capes]] in {{BFF}}. [[Category:Equipment]]"
wikitext
text/x-wiki
[[Capes]] in {{BFF}}.
[[Category:Equipment]]
610b5d39e64ba2027967f7f378bcd46fa727934f
Module:String
828
556
872
2025-08-21T20:01:02Z
Sharparam
284703
Created page with "--[[ This module is intended to provide access to basic string functions. Most of the functions provided here can be invoked with named parameters, unnamed parameters, or a mixture. If named parameters are used, Mediawiki will automatically remove any leading or trailing whitespace from the parameter. Depending on the intended use, it may be advantageous to either preserve or remove such whitespace. Global options ignore_errors: If set to 'true' or 1, any error c..."
Scribunto
text/plain
--[[
This module is intended to provide access to basic string functions.
Most of the functions provided here can be invoked with named parameters,
unnamed parameters, or a mixture. If named parameters are used, Mediawiki will
automatically remove any leading or trailing whitespace from the parameter.
Depending on the intended use, it may be advantageous to either preserve or
remove such whitespace.
Global options
ignore_errors: If set to 'true' or 1, any error condition will result in
an empty string being returned rather than an error message.
error_category: If an error occurs, specifies the name of a category to
include with the error message. The default category is
[Category:Errors reported by Module String].
no_category: If set to 'true' or 1, no category will be added if an error
is generated.
Unit tests for this module are available at Module:String/tests.
]]
local str = {}
--[[
len
This function returns the length of the target string.
Usage:
{{#invoke:String|len|target_string|}}
OR
{{#invoke:String|len|s=target_string}}
Parameters
s: The string whose length to report
If invoked using named parameters, Mediawiki will automatically remove any leading or
trailing whitespace from the target string.
]]
function str.len( frame )
local new_args = str._getParameters( frame.args, {'s'} )
local s = new_args['s'] or ''
return mw.ustring.len( s )
end
--[[
sub
This function returns a substring of the target string at specified indices.
Usage:
{{#invoke:String|sub|target_string|start_index|end_index}}
OR
{{#invoke:String|sub|s=target_string|i=start_index|j=end_index}}
Parameters
s: The string to return a subset of
i: The first index of the substring to return, defaults to 1.
j: The last index of the string to return, defaults to the last character.
The first character of the string is assigned an index of 1. If either i or j
is a negative value, it is interpreted the same as selecting a character by
counting from the end of the string. Hence, a value of -1 is the same as
selecting the last character of the string.
If the requested indices are out of range for the given string, an error is
reported.
]]
function str.sub( frame )
local new_args = str._getParameters( frame.args, { 's', 'i', 'j' } )
local s = new_args['s'] or ''
local i = tonumber( new_args['i'] ) or 1
local j = tonumber( new_args['j'] ) or -1
local len = mw.ustring.len( s )
-- Convert negatives for range checking
if i < 0 then
i = len + i + 1
end
if j < 0 then
j = len + j + 1
end
if i > len or j > len or i < 1 or j < 1 then
return str._error( 'String subset index out of range' )
end
if j < i then
return str._error( 'String subset indices out of order' )
end
return mw.ustring.sub( s, i, j )
end
--[[
This function implements that features of {{str sub old}} and is kept in order
to maintain these older templates.
]]
function str.sublength( frame )
local i = tonumber( frame.args.i ) or 0
local len = tonumber( frame.args.len )
return mw.ustring.sub( frame.args.s, i + 1, len and ( i + len ) )
end
--[[
_match
This function returns a substring from the source string that matches a
specified pattern. It is exported for use in other modules
Usage:
strmatch = require("Module:String")._match
sresult = strmatch( s, pattern, start, match, plain, nomatch )
Parameters
s: The string to search
pattern: The pattern or string to find within the string
start: The index within the source string to start the search. The first
character of the string has index 1. Defaults to 1.
match: In some cases it may be possible to make multiple matches on a single
string. This specifies which match to return, where the first match is
match= 1. If a negative number is specified then a match is returned
counting from the last match. Hence match = -1 is the same as requesting
the last match. Defaults to 1.
plain: A flag indicating that the pattern should be understood as plain
text. Defaults to false.
nomatch: If no match is found, output the "nomatch" value rather than an error.
For information on constructing Lua patterns, a form of [regular expression], see:
* http://www.lua.org/manual/5.1/manual.html#5.4.1
* http://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Patterns
* http://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Ustring_patterns
]]
-- This sub-routine is exported for use in other modules
function str._match( s, pattern, start, match_index, plain_flag, nomatch )
if s == '' then
return str._error( 'Target string is empty' )
end
if pattern == '' then
return str._error( 'Pattern string is empty' )
end
start = tonumber(start) or 1
if math.abs(start) < 1 or math.abs(start) > mw.ustring.len( s ) then
return str._error( 'Requested start is out of range' )
end
if match_index == 0 then
return str._error( 'Match index is out of range' )
end
if plain_flag then
pattern = str._escapePattern( pattern )
end
local result
if match_index == 1 then
-- Find first match is simple case
result = mw.ustring.match( s, pattern, start )
else
if start > 1 then
s = mw.ustring.sub( s, start )
end
local iterator = mw.ustring.gmatch(s, pattern)
if match_index > 0 then
-- Forward search
for w in iterator do
match_index = match_index - 1
if match_index == 0 then
result = w
break
end
end
else
-- Reverse search
local result_table = {}
local count = 1
for w in iterator do
result_table[count] = w
count = count + 1
end
result = result_table[ count + match_index ]
end
end
if result == nil then
if nomatch == nil then
return str._error( 'Match not found' )
else
return nomatch
end
else
return result
end
end
--[[
match
This function returns a substring from the source string that matches a
specified pattern.
Usage:
{{#invoke:String|match|source_string|pattern_string|start_index|match_number|plain_flag|nomatch_output}}
OR
{{#invoke:String|match|s=source_string|pattern=pattern_string|start=start_index
|match=match_number|plain=plain_flag|nomatch=nomatch_output}}
Parameters
s: The string to search
pattern: The pattern or string to find within the string
start: The index within the source string to start the search. The first
character of the string has index 1. Defaults to 1.
match: In some cases it may be possible to make multiple matches on a single
string. This specifies which match to return, where the first match is
match= 1. If a negative number is specified then a match is returned
counting from the last match. Hence match = -1 is the same as requesting
the last match. Defaults to 1.
plain: A flag indicating that the pattern should be understood as plain
text. Defaults to false.
nomatch: If no match is found, output the "nomatch" value rather than an error.
If invoked using named parameters, Mediawiki will automatically remove any leading or
trailing whitespace from each string. In some circumstances this is desirable, in
other cases one may want to preserve the whitespace.
If the match_number or start_index are out of range for the string being queried, then
this function generates an error. An error is also generated if no match is found.
If one adds the parameter ignore_errors=true, then the error will be suppressed and
an empty string will be returned on any failure.
For information on constructing Lua patterns, a form of [regular expression], see:
* http://www.lua.org/manual/5.1/manual.html#5.4.1
* http://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Patterns
* http://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Ustring_patterns
]]
-- This is the entry point for #invoke:String|match
function str.match( frame )
local new_args = str._getParameters( frame.args, {'s', 'pattern', 'start', 'match', 'plain', 'nomatch'} )
local s = new_args['s'] or ''
local start = tonumber( new_args['start'] ) or 1
local plain_flag = str._getBoolean( new_args['plain'] or false )
local pattern = new_args['pattern'] or ''
local match_index = math.floor( tonumber(new_args['match']) or 1 )
local nomatch = new_args['nomatch']
return str._match( s, pattern, start, match_index, plain_flag, nomatch )
end
--[[
pos
This function returns a single character from the target string at position pos.
Usage:
{{#invoke:String|pos|target_string|index_value}}
OR
{{#invoke:String|pos|target=target_string|pos=index_value}}
Parameters
target: The string to search
pos: The index for the character to return
If invoked using named parameters, Mediawiki will automatically remove any leading or
trailing whitespace from the target string. In some circumstances this is desirable, in
other cases one may want to preserve the whitespace.
The first character has an index value of 1.
If one requests a negative value, this function will select a character by counting backwards
from the end of the string. In other words pos = -1 is the same as asking for the last character.
A requested value of zero, or a value greater than the length of the string returns an error.
]]
function str.pos( frame )
local new_args = str._getParameters( frame.args, {'target', 'pos'} )
local target_str = new_args['target'] or ''
local pos = tonumber( new_args['pos'] ) or 0
if pos == 0 or math.abs(pos) > mw.ustring.len( target_str ) then
return str._error( 'String index out of range' )
end
return mw.ustring.sub( target_str, pos, pos )
end
--[[
str_find
This function duplicates the behavior of {{str_find}}, including all of its quirks.
This is provided in order to support existing templates, but is NOT RECOMMENDED for
new code and templates. New code is recommended to use the "find" function instead.
Returns the first index in "source" that is a match to "target". Indexing is 1-based,
and the function returns -1 if the "target" string is not present in "source".
Important Note: If the "target" string is empty / missing, this function returns a
value of "1", which is generally unexpected behavior, and must be accounted for
separatetly.
]]
function str.str_find( frame )
local new_args = str._getParameters( frame.args, {'source', 'target'} )
local source_str = new_args['source'] or ''
local target_str = new_args['target'] or ''
if target_str == '' then
return 1
end
local start = mw.ustring.find( source_str, target_str, 1, true )
if start == nil then
start = -1
end
return start
end
--[[
find
This function allows one to search for a target string or pattern within another
string.
Usage:
{{#invoke:String|find|source_str|target_string|start_index|plain_flag}}
OR
{{#invoke:String|find|source=source_str|target=target_str|start=start_index|plain=plain_flag}}
Parameters
source: The string to search
target: The string or pattern to find within source
start: The index within the source string to start the search, defaults to 1
plain: Boolean flag indicating that target should be understood as plain
text and not as a Lua style regular expression, defaults to true
If invoked using named parameters, Mediawiki will automatically remove any leading or
trailing whitespace from the parameter. In some circumstances this is desirable, in
other cases one may want to preserve the whitespace.
This function returns the first index >= "start" where "target" can be found
within "source". Indices are 1-based. If "target" is not found, then this
function returns 0. If either "source" or "target" are missing / empty, this
function also returns 0.
This function should be safe for UTF-8 strings.
]]
function str.find( frame )
local new_args = str._getParameters( frame.args, {'source', 'target', 'start', 'plain' } )
local source_str = new_args['source'] or ''
local pattern = new_args['target'] or ''
local start_pos = tonumber(new_args['start']) or 1
local plain = new_args['plain'] or true
if source_str == '' or pattern == '' then
return 0
end
plain = str._getBoolean( plain )
local start = mw.ustring.find( source_str, pattern, start_pos, plain )
if start == nil then
start = 0
end
return start
end
--[[
replace
This function allows one to replace a target string or pattern within another
string.
Usage:
{{#invoke:String|replace|source_str|pattern_string|replace_string|replacement_count|plain_flag}}
OR
{{#invoke:String|replace|source=source_string|pattern=pattern_string|replace=replace_string|
count=replacement_count|plain=plain_flag}}
Parameters
source: The string to search
pattern: The string or pattern to find within source
replace: The replacement text
count: The number of occurences to replace, defaults to all.
plain: Boolean flag indicating that pattern should be understood as plain
text and not as a Lua style regular expression, defaults to true
]]
function str.replace( frame )
local new_args = str._getParameters( frame.args, {'source', 'pattern', 'replace', 'count', 'plain' } )
local source_str = new_args['source'] or ''
local pattern = new_args['pattern'] or ''
local replace = new_args['replace'] or ''
local count = tonumber( new_args['count'] )
local plain = new_args['plain'] or true
if source_str == '' or pattern == '' then
return source_str
end
plain = str._getBoolean( plain )
if plain then
pattern = str._escapePattern( pattern )
replace = string.gsub( replace, "%%", "%%%%" ) --Only need to escape replacement sequences.
end
local result
if count ~= nil then
result = mw.ustring.gsub( source_str, pattern, replace, count )
else
result = mw.ustring.gsub( source_str, pattern, replace )
end
return result
end
--[[
simple function to pipe string.rep to templates.
]]
function str.rep( frame )
local repetitions = tonumber( frame.args[2] )
if not repetitions then
return str._error( 'function rep expects a number as second parameter, received "' .. ( frame.args[2] or '' ) .. '"' )
end
return string.rep( frame.args[1] or '', repetitions )
end
--[[
escapePattern
This function escapes special characters from a Lua string pattern. See [1]
for details on how patterns work.
[1] https://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Patterns
Usage:
{{#invoke:String|escapePattern|pattern_string}}
Parameters
pattern_string: The pattern string to escape.
]]
function str.escapePattern( frame )
local pattern_str = frame.args[1]
if not pattern_str then
return str._error( 'No pattern string specified' )
end
local result = str._escapePattern( pattern_str )
return result
end
--[[
count
This function counts the number of occurrences of one string in another.
]]
function str.count(frame)
local args = str._getParameters(frame.args, {'source', 'pattern', 'plain'})
local source = args.source or ''
local pattern = args.pattern or ''
local plain = str._getBoolean(args.plain or true)
if plain then
pattern = str._escapePattern(pattern)
end
local _, count = mw.ustring.gsub(source, pattern, '')
return count
end
--[[
endswith
This function determines whether a string ends with another string.
]]
function str.endswith(frame)
local args = str._getParameters(frame.args, {'source', 'pattern'})
local source = args.source or ''
local pattern = args.pattern or ''
if pattern == '' then
-- All strings end with the empty string.
return "yes"
end
if mw.ustring.sub(source, -mw.ustring.len(pattern), -1) == pattern then
return "yes"
else
return ""
end
end
--[[
join
Join all non empty arguments together; the first argument is the separator.
Usage:
{{#invoke:String|join|sep|one|two|three}}
]]
function str.join(frame)
local args = {}
local sep
for _, v in ipairs( frame.args ) do
if sep then
if v ~= '' then
table.insert(args, v)
end
else
sep = v
end
end
return table.concat( args, sep or '' )
end
-- findpagetext returns the position of a piece of text in a page
-- First positional parameter or |text is the search text
-- Optional parameter |title is the page title, defaults to current page
-- Optional parameter |plain is either true for plain search (default) or false for Lua pattern search
-- Optional parameter |nomatch is the return value when no match is found; default is nil
function str._findpagetext(args)
-- process parameters
local nomatch = args.nomatch or ""
if nomatch == "" then nomatch = nil end
--
local text = mw.text.trim(args[1] or args.text or "")
if text == "" then return nil end
--
local title = args.title or ""
local titleobj
if title == "" then
titleobj = mw.title.getCurrentTitle()
else
titleobj = mw.title.new(title)
end
--
local plain = args.plain or ""
if plain:sub(1, 1) == "f" then plain = false else plain = true end
-- get the page content and look for 'text' - return position or nomatch
local content = titleobj and titleobj:getContent()
return content and mw.ustring.find(content, text, 1, plain) or nomatch
end
function str.findpagetext(frame)
local args = frame.args
local pargs = frame:getParent().args
for k, v in pairs(pargs) do
args[k] = v
end
if not (args[1] or args.text) then return nil end
-- just the first value
return (str._findpagetext(args))
end
--[[
Helper function that populates the argument list given that user may need to use a mix of
named and unnamed parameters. This is relevant because named parameters are not
identical to unnamed parameters due to string trimming, and when dealing with strings
we sometimes want to either preserve or remove that whitespace depending on the application.
]]
function str._getParameters( frame_args, arg_list )
local new_args = {}
local index = 1
local value
for _, arg in ipairs( arg_list ) do
value = frame_args[arg]
if value == nil then
value = frame_args[index]
index = index + 1
end
new_args[arg] = value
end
return new_args
end
--[[
Helper function to handle error messages.
]]
function str._error( error_str )
local frame = mw.getCurrentFrame()
local error_category = frame.args.error_category or 'Errors reported by Module String'
local ignore_errors = frame.args.ignore_errors or false
local no_category = frame.args.no_category or false
if str._getBoolean(ignore_errors) then
return ''
end
local error_str = '<strong class="error">String Module Error: ' .. error_str .. '</strong>'
if error_category ~= '' and not str._getBoolean( no_category ) then
error_str = '[[Category:' .. error_category .. ']]' .. error_str
end
return error_str
end
--[[
Helper Function to interpret boolean strings
]]
function str._getBoolean( boolean_str )
local boolean_value
if type( boolean_str ) == 'string' then
boolean_str = boolean_str:lower()
if boolean_str == 'false' or boolean_str == 'no' or boolean_str == '0'
or boolean_str == '' then
boolean_value = false
else
boolean_value = true
end
elseif type( boolean_str ) == 'boolean' then
boolean_value = boolean_str
else
error( 'No boolean value found' )
end
return boolean_value
end
--[[
Helper function that escapes all pattern characters so that they will be treated
as plain text.
]]
function str._escapePattern( pattern_str )
return ( string.gsub( pattern_str, "[%(%)%.%%%+%-%*%?%[%^%$%]]", "%%%0" ) )
end
return str
a3717be7740b8299448ef51ae8300caf00c3cac6
Module:String/doc
828
557
873
2025-08-21T20:02:33Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Module:String|Module and documentation on Wikipedia]] <noinclude>[[Category:Module documentation pages]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Module:String|Module and documentation on Wikipedia]]
<noinclude>[[Category:Module documentation pages]]</noinclude>
762229bd4719989f582c0ab0a6164c27e7dd989c
Template:Main other
10
558
874
2025-08-21T20:05:16Z
Sharparam
284703
Created page with "{{#switch: <!--If no or empty "demospace" parameter then detect namespace--> {{#if:{{{demospace|}}} | {{lc: {{{demospace}}} }} <!--Use lower case "demospace"--> | {{#ifeq:{{NAMESPACE}}|{{ns:0}} | main | other }} }} | main = {{{1|}}} | other | #default = {{{2|}}} }}<noinclude> {{documentation}} <!-- Add categories to the /doc subpage; interwikis go to Wikidata, thank you! --> </noinclude>"
wikitext
text/x-wiki
{{#switch:
<!--If no or empty "demospace" parameter then detect namespace-->
{{#if:{{{demospace|}}}
| {{lc: {{{demospace}}} }} <!--Use lower case "demospace"-->
| {{#ifeq:{{NAMESPACE}}|{{ns:0}}
| main
| other
}}
}}
| main = {{{1|}}}
| other
| #default = {{{2|}}}
}}<noinclude>
{{documentation}}
<!-- Add categories to the /doc subpage; interwikis go to Wikidata, thank you! -->
</noinclude>
86ad907ffeea3cc545159e00cd1f2d6433946450
Template:Main other/doc
10
559
875
2025-08-21T20:07:20Z
Sharparam
284703
Created page with "== External links == * [[mw:Template:Main other|Template on MediaWiki]] <includeonly>{{Sandbox other||[[Category:Namespace manipulation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[mw:Template:Main other|Template on MediaWiki]]
<includeonly>{{Sandbox other||[[Category:Namespace manipulation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
89ed25ee7894a7a296aa3e7017ad4b3942444395
Category:Namespace manipulation templates
14
560
876
2025-08-21T20:07:33Z
Sharparam
284703
Created blank page
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
Template:Infobox/Ring
10
561
877
2025-08-21T20:08:18Z
Sharparam
284703
Created page with "<includeonly>{{#invoke:infobox|main | kind = ring | title = {{{title|{{PAGENAME}}}}} | image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}} }}{{Main other|[[Category:Rings]]}}</includeonly><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{#invoke:infobox|main
| kind = ring
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
}}{{Main other|[[Category:Rings]]}}</includeonly><noinclude>{{Documentation}}</noinclude>
4e47a92e54ae186ca95884a7814fd17d484e6f19
Template:Infobox/Ring/doc
10
562
878
2025-08-21T20:09:51Z
Sharparam
284703
Created page with "== Example == {{Infobox/Ring | title = Cool Ring | image = Cool Ring.png }} <syntaxhighlight lang="wikitext"> {{Infobox/Ring | title = Cool Ring | image = Cool Ring.png }} </syntaxhighlight> <includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== Example ==
{{Infobox/Ring
| title = Cool Ring
| image = Cool Ring.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Ring
| title = Cool Ring
| image = Cool Ring.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
3a0fcf05ffaac79fbaebadf1c4c33a7e5bb61b00
Amulets
0
444
879
654
2025-08-21T20:11:19Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox/Amulets}}
[[Category:Amulets]]
a1dffe598e440da35929b53420fd1a9c97aca8d4
Category:Amulets
14
563
880
2025-08-21T20:11:42Z
Sharparam
284703
Created page with "[[Amulets]] in {{BFF}}. [[Category:Equipment]]"
wikitext
text/x-wiki
[[Amulets]] in {{BFF}}.
[[Category:Equipment]]
0df5616094b34d958f04a0b771cb3febedfb2a3e
Template:Infobox/Amulet
10
564
881
2025-08-21T20:13:12Z
Sharparam
284703
Created page with "<includeonly>{{#invoke:infobox|main | kind = amulet | title = {{{title|{{PAGENAME}}}}} | image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}} }} {{Main other|[[Categoryr:Amulets]]}}</includeonly> <noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{#invoke:infobox|main
| kind = amulet
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
}}
{{Main other|[[Categoryr:Amulets]]}}</includeonly>
<noinclude>{{Documentation}}</noinclude>
59c7689eb27247274be01dad72a94fd39ab0f116
883
881
2025-08-21T20:15:25Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
<includeonly>{{#invoke:infobox|main
| kind = amulet
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
}}
{{Main other|[[Category:Amulets]]}}</includeonly>
<noinclude>{{Documentation}}</noinclude>
98dd406e69d315cc644122750f3274345ee67c16
Template:Infobox/Amulet/doc
10
565
882
2025-08-21T20:14:12Z
Sharparam
284703
Created page with "== Example == {{Infobox/Amulet | title = Amulet of Kings | image = Amulet of Kings.png }} <syntaxhighlight lang="wikitext"> {{Infobox/Amulet | title = Amulet of Kings | image = Amulet of Kings.png }} </syntaxhighlight> <includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== Example ==
{{Infobox/Amulet
| title = Amulet of Kings
| image = Amulet of Kings.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Amulet
| title = Amulet of Kings
| image = Amulet of Kings.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
407f3f75b4941c92d58979ccedaae629985e2034
Category:Armor sets
14
566
884
2025-08-21T20:17:24Z
Sharparam
284703
Created page with "[[Armor sets]] in {{BFF}}. [[Category:Armor]]"
wikitext
text/x-wiki
[[Armor sets]] in {{BFF}}.
[[Category:Armor]]
4261c8c87af5c69c1fd95f9b534cdaa03bda2565
Category:Armor
14
567
885
2025-08-21T20:17:39Z
Sharparam
284703
Created page with "[[Armor]] in {{BFF}}. [[Category:Equipment]]"
wikitext
text/x-wiki
[[Armor]] in {{BFF}}.
[[Category:Equipment]]
1d8c33f61240ee031af7c8bc9003e6c464e562f2
Category:Shields
14
568
886
2025-08-21T20:18:20Z
Sharparam
284703
Created page with "[[Shields]] in {{BFF}}. [[Category:Equipment]]"
wikitext
text/x-wiki
[[Shields]] in {{BFF}}.
[[Category:Equipment]]
feeed44abd585d1042d90c77b1d9917cbbfc6847
Category:Dual Wields
14
469
887
703
2025-08-21T20:19:05Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Category:Two-handed weapons]]
[[Category:Weapons]]
d1d70b00110573e778b25c45bea57d07228f8da8
Category:Two-handed weapons
14
569
888
2025-08-21T20:19:19Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Category:Weapons]]
febdf29cf9dcbef034e184720fe19a5ac5f353d8
Category:Staves
14
570
889
2025-08-21T20:20:01Z
Sharparam
284703
Created page with "[[Staves]] in {{BFF}}. [[Category:Ranged weapons]]"
wikitext
text/x-wiki
[[Staves]] in {{BFF}}.
[[Category:Ranged weapons]]
fbcb5b72d01c72093ae71f361c912b871222d451
Category:Ranged weapons
14
571
890
2025-08-21T20:20:16Z
Sharparam
284703
Created page with "[[Category:Weapons]]"
wikitext
text/x-wiki
[[Category:Weapons]]
febdf29cf9dcbef034e184720fe19a5ac5f353d8
Template:Infobox/Weapon
10
451
891
667
2025-08-21T20:23:12Z
Sharparam
284703
Improve categorisation
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
57581ea141193600dd7a356e55ba1811c1743f42
Template:Infobox/Item
10
417
892
597
2025-08-21T20:28:13Z
Sharparam
284703
Improve categorisation
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind=item
| sep=,
| title={{{title|{{PAGENAME}}}}}
| image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=DescriptionSection
| DescriptionSection=Description
| DescriptionSection_label=Description
| Description_nolabel=yes
}}{{Main other|{{#switch:{{lc:{{{type|}}}}}
| essential = [[Category:Essential items]]
| upgrade = [[Category:Upgrade items]]
| #default = [[Category:Items]]
}}}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]</noinclude>
9bd3533dad3a53907b2b069897e3830faeed6721
Ability Splinter
0
430
893
623
2025-08-21T20:29:24Z
Sharparam
284703
Add infobox
wikitext
text/x-wiki
{{Infobox/Item
| type = essential
| image = Ability Splinter.png
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}. It is used to equip and change [[abilities]].
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found near the [[Paladin Mace]]. Facing where the mace is, head left and slightly behind and look behind the large pillar to find the item. || {{coords|-4581|-7721|5575}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and keep right until you get to the room with a staircase going down. Before heading down the staircase, walk around it on its right and check the corner to find the item. || {{coords|1120|-7590|161}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and take the left path. In the outdoors area, head up the stairs and take the second right to get to the edge of the cliff with a bunch of graves. The item can be found near one of the graves. || {{coords|1321|-8034|190}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || Starting from the [[Homunculus]], go through the doorway and take the left path. In the outdoors area, head up the stairs and take the left path to a cliff. Climb the cliff by repeatedly tapping the jump button. Once at the top, take the path leading down and follow it past a group of buildings (where the [[Soul Reaper]] can be found). Past the buildings are a set of graves with the item on top of one of them.
|}
{{Navbox/Items}}
f41049ed237d82ef6acd68f7fb96cabec6e868ee
Handler Echo
0
421
894
605
2025-08-21T20:30:16Z
Sharparam
284703
Add type to infobox
wikitext
text/x-wiki
{{Infobox/Item
| image = Handler Echo.png
| title = {{PAGENAME}}
| type = essential
| Description = An obscure residue used to supplement [[The Handler|the Handler's]] capabilities. [[The Handler]] can use this to upgrade [[equipment]] more effectively.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] used to level up [[The Handler]], in order to increase the max level equipment can be upgraded to.
== Usage ==
If the item is in your inventory, [[The Handler]] will automatically level up when you next interact with her. A message will also pop up in the bottom right corner of the screen informing you of the new synchronization level.
== Acquisition ==
* Drops from [[Konrad the Traitor]].
* Can drop from samurai enemies in [[Uranopolis]] (limited to one drop).
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Rain District]] || Up some stairs. || {{coords|-36697.35|-17753.66|12174.48}}
|-
| [[Asylum]] || In the spiral staircase with the shortcut door to the courtyard there is a floating ghost. Move through the ghost and the echo will be right behind it. || {{coords|-4225|6824|9253}}
|-
| [[Desert]] || In the big building after the sand worm, where Yaroslav's crew is. The echo is sitting on a toppled pillar. || {{coords|3720|1159|-1397}}
|}
{{Navbox/Items}}
dc3fe45dda237d7748a0cf867d250cff08fedcec
Homunculus Mirage
0
423
895
609
2025-08-21T20:30:47Z
Sharparam
284703
Add type to infobox
wikitext
text/x-wiki
{{Infobox/Item
| type = essential
| tabs=Normal,Husk
| Normal_title = Homunculus Mirage
| Husk_title = Humunculus Mirage Husk
| images = [[File:Homunculus Mirage.png|300px]],[[File:Homunculus Mirage Husk.png|300px]]
| Normal_Description = The Homunculus triggers its ability only when your vital signs have ceased – reassembling your body on a molecular level elsewhere while keeping your consciousness intact, allowing for seamless and instantaneous relocation.
| Husk_Description = The husk of the Homunculus stores your current state and consciousness. Return at the Homunculus to combine the two again, allowing you to place the Homunculus elsewhere.
}}
{{Navbox/Items}}
903487e48beaa0c93f10e0a63a5d4c122f9906d6
Old Key
0
429
896
621
2025-08-21T20:31:16Z
Sharparam
284703
Add type to infobox
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Old Key.png
| type = essential
| Description = An old, rusted key that unlocks the gate in the old [[Monastery|monastery]].
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Location ==
{{coords|19328.57|-41596.65|3.83}}
Found at the top of the [[Monastery]], behind [[Konrad the Traitor]]. Killing the boss is not required to pick it up.
== Usage ==
Unlocks the gate at the top of the [[Monastery]], found near the entrance to [[Konrad the Traitor|Konrad the Traitor's]] boss arena (keep going past the entrance instead of entering it).
{{Navbox/Items}}
35b7568dcd6463e558a8716ab5e0df86bc0371e0
Perk Essence
0
424
897
611
2025-08-21T20:31:35Z
Sharparam
284703
Add type to infobox
wikitext
text/x-wiki
{{Infobox/Item
| type = essential
| tabs = Stable,Unstable
| images = [[File:Perk Essence.png|300px]],[[File:Unstable Perk Essence.png|300px]]
| Stable_title = Perk Essence
| Unstable_title = Unstable Perk Essence
| Stable_Description = An artifact used in the process of embedding perks.
| Unstable_Description = Get to a checkpoint to turn it into a perk, on death goes back to it's [sic] original location.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] used to acquire [[perks]] or perk upgrades.
== Acquisition ==
The unstable variant drops from some [[bosses]] (excluding mini-bosses), bringing it to a [[homunculus]] without dying stabilises it. It has to be brought to a normal homunculus, not one spawned by the [[Homunculus Mirage]].
Dying on the way to a homunculus while the item is still in its unstable form will respawn it in the boss's arena, forcing the player to go back and pick it up again.
{{Navbox/Items}}
06df31e4640020666782a66b6361d649f91516a8
Plagued Blood
0
422
898
607
2025-08-21T20:31:52Z
Sharparam
284703
Add type to infobox
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Plagued Blood.png
| type = essential
| Description = Harvested from a burial site, this unsettling vial contains a sample of plagued blood belonging to a Revenant.
}}
== Location ==
{{coords|-3898|1671|1585}}
Located at the top of the big tower in [[Asylum|the asylum]], after climbing a staircase into a room with a bunch of empty bookshelves, look to your right to see the item on a table.
== Usage ==
Having this item in your inventory allows for spawning some optional bosses.
* [[Plagued Warden]]
* [[Plagued Revenant]]
{{Navbox/Items}}
14acdb051f6e55b447efed3ac05a0b7c62007bc6
Scanner
0
374
899
511
2025-08-21T20:32:13Z
Sharparam
284703
Add type to infobox
wikitext
text/x-wiki
{{Infobox/Item
| image = Scanner.png
| title = {{PAGENAME}}
| type = essential
| Description = Captures and interprets data across hidden and abstract dimensions, revealing information that transcends conventional spatial and temporal limits, providing a comprehensive view of both visible and imperceptible phenomena.
}}
The '''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Overview ==
Activating the item scans the area around the player, revealing important interactables like [[data logs]] and ladders.
{{Navbox/Items}}
[[Category:Lore]]
6dde4eac60da31a5e41858bdeed680e9dda22183
Upgrade Splinter
0
432
900
627
2025-08-21T20:33:07Z
Sharparam
284703
Add infobox
wikitext
text/x-wiki
{{Infobox/Item
| image = Upgrade Splinter.png
| type = upgrade
}}
'''{{PAGENAME}}''' is an item found in {{BFF}} used to enhance [[weapons]] and [[armor]] to Mk 1, 2, and 3.
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found in the first big rectangular structure with pillars, near the [[Paladin Mace]]. Facing where the mace is, head right and past the red traffic light to find the item sitting on a ledge. || {{coords|-5173|-1105|5626}}
|}
{{Navbox/Items}}
b9f020a57eb70f08cefe430eb0760284abd62b57
901
900
2025-08-21T20:34:13Z
Sharparam
284703
Add "See also" for [[Upgrade Module]]
wikitext
text/x-wiki
{{Infobox/Item
| image = Upgrade Splinter.png
| type = upgrade
}}
'''{{PAGENAME}}''' is an item found in {{BFF}} used to enhance [[weapons]] and [[armor]] to Mk 1, 2, and 3.
== Locations ==
{| class="wikitable"
! Area !! Description !! Coordinates
|-
| [[Deluge]] || Found in the first big rectangular structure with pillars, near the [[Paladin Mace]]. Facing where the mace is, head right and past the red traffic light to find the item sitting on a ledge. || {{coords|-5173|-1105|5626}}
|}
== See also ==
* [[Upgrade Module]] – To upgrade to Mk 4 and 5.
{{Navbox/Items}}
4d57ed9542043b3fdb63d30bfaa147497119f15c
Upgrade Module
0
425
902
613
2025-08-21T20:35:20Z
Sharparam
284703
Add type to infobox and note for [[Upgrade Splinter]]
wikitext
text/x-wiki
{{Infobox/Item
| title = {{PAGENAME}}
| image = Upgrade Module.png
| type = upgrade
| Description = A rare artifact used in the process of upgrading gear.
}}
'''{{PAGENAME}}''' is an [[Upgrade items|upgrade item]] in {{BFF}}. It is used to upgrade equipment to Mk 4 and 5.
== See also ==
* [[Upgrade Splinter]] – To upgrade to Mk 1, 2, and 3.
{{Navbox/Items}}
c999ea8a43c85cc912948b06f8657a194aeea34e
Category:Upgrade items
14
419
903
601
2025-08-21T20:35:43Z
Sharparam
284703
Change category to essential items
wikitext
text/x-wiki
[[Category:Essential items]]
4679e283883b6184f5cfc91470c12804eae20cb9
Category:Weapons
14
468
904
701
2025-08-21T20:36:27Z
Sharparam
284703
Add link to [[Weapons]] and category
wikitext
text/x-wiki
[[Weapons]] are equipment the player can use to damage monsters and defend themselves.
[[Category:Equipment]]
9906cbd32ff766765cc3704c8230f08d17b42c05
Category:One-handed weapons
14
572
905
2025-08-21T20:36:53Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Category:Weapons]]
febdf29cf9dcbef034e184720fe19a5ac5f353d8
Category:Longbows
14
573
906
2025-08-21T20:37:23Z
Sharparam
284703
Created page with "[[Category:Ranged weapons]]"
wikitext
text/x-wiki
[[Category:Ranged weapons]]
f11922e287203334625452a716db9708dbdb2fe2
Arcane Bow
0
509
907
783
2025-08-21T20:37:51Z
Sharparam
284703
Fix type
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Arcane Bow.png
| Type = Longbow
| Damage type = Sharp
| Speed = Fast
| Passives = Vermillion Judgment
| Abilities = Arrow Twister
| Mk2_Damage_min = 184
| Mk2_Damage_max = 197
| Mk3_Damage_min = 251
| Mk3_Damage_max = 267
| Mk4_Damage_min = 292
| Mk4_Damage_max = 312
| Mk5_Damage_min = 334
| Mk5_Damage_max = 356
}}
'''{{PAGENAME}}''' is a [[Bows|bow]] in {{BFF}}.
== Location ==
{{coords|1261|-8400|1563}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the left path. When in the outdoors area, head into the path on the right before the big stairs. Take the ladder at the end getting up onto a building, and then the next one. The item will be in the corner of the roof on a corpse.
{{Navbox/Weapons}}
c71bb9590b06d49cf37461cb2e73d4ceb69e4775
Taskmaster
0
510
908
785
2025-08-21T20:38:10Z
Sharparam
284703
Fix type
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Taskmaster.png
| Type = Longbow
| Damage type = Sharp
| Speed = Fast
| Passives = Rapid Fire, Critical Strike
| Mk2_Damage_min = 240
| Mk2_Damage_max = 256
}}
'''{{PAGENAME}}''' is a [[Ranged weapons|ranged weapon]] in {{BFF}}.
== Location ==
{{coord|4052|1265|-1412}}
Located in the [[Desert]]. After meeting [[Yaroslav|Yaroslav's]] crew and passing through the passage to the big open area, look slightly to the left and you'll see the bow resting against some run down brick arches.
{{Navbox/Weapons}}
2e790f8146f1b835c896cbaa546ab613a5058893
File:Sharparam.png
6
574
909
2025-08-21T20:39:28Z
Sharparam
284703
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
910
909
2025-08-21T20:40:07Z
Sharparam
284703
Protected "[[File:Sharparam.png]]": Profile image for a user ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite) [Upload=Allow only administrators] (indefinite))
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
Blade Dash
0
575
912
911
2025-08-21T20:42:30Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ability
| image = OrientalDash.png
| title = Blade Dash
| Cost = 45
| Cooldown = 15
| Description = Swing your weapon several times, dealing damage to all enemies in a frontal cone.
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
d8d63bcf9e2ab9e7610a637cbfae9e493d98a50d
Whirlwind Strike
0
576
914
913
2025-08-21T20:42:30Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ability
| image = OrientalSpin.png
| title = Whirlwind Strike
| Cost = 75
| Cooldown = 25
| Description = Swing your weapon several times, dealing damage to all enemies in a frontal cone.
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
e6c1e11c6f18f8785af475d924c7d62d672fe3b3
Divine Blessing
0
577
916
915
2025-08-21T20:42:30Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ability
| image = Divine Blessing.png
| title = {{PAGENAME}}
| Cost = 125
| Cooldown = 30
| Description = Restore 30% of your total [[HP]] and deal damage to all nearby [[Plague|plagued]] [[enemies]].
}}
'''{{PAGENAME}}''' is a [[Weapons|weapon]] [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
552de679ebb2751ab76780e73c8c534074b51109
Template:Navbox/Abilities
10
578
917
2025-08-21T20:43:15Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Abilities | title = Abilities | list1 = * [[Blade Dash]] * [[Divine Blessing]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = Abilities
| list1 =
* [[Blade Dash]]
* [[Divine Blessing]]
}}<noinclude>{{Documentation}}</noinclude>
248794f927ba5a321603494f50191d9afdccac76
918
917
2025-08-21T20:43:45Z
Sharparam
284703
Add [[Whirlwind Strike]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = Abilities
| list1 =
* [[Blade Dash]]
* [[Divine Blessing]]
* [[Whirlwind Strike]]
}}<noinclude>{{Documentation}}</noinclude>
1c55ce1234b5272317e8123c68b027c0096255b8
920
918
2025-08-21T20:45:06Z
Sharparam
284703
Link to abilities page
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = [[Abilities]]
| list1 =
* [[Blade Dash]]
* [[Divine Blessing]]
* [[Whirlwind Strike]]
}}<noinclude>{{Documentation}}</noinclude>
b98da907f8e5f4b2ad9e5c5c7fc0502d0bf982cc
Template:Navbox/Abilities/doc
10
579
919
2025-08-21T20:44:22Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
87827f6829955b934e0e8073491c0fef23954bf8
Abilities
0
580
921
2025-08-21T20:46:54Z
Sharparam
284703
Created page with "'''Abilities''' are special skills that can be found on some [[weapons]]. {{Navbox/Abilities}} [[Category:Abilities]]"
wikitext
text/x-wiki
'''Abilities''' are special skills that can be found on some [[weapons]].
{{Navbox/Abilities}}
[[Category:Abilities]]
4fe632a6dc4cee00686ec11acc1158dbb0dfb610
Category:Abilities
14
581
922
2025-08-21T20:47:08Z
Sharparam
284703
Created page with "[[Abilities]] in {{BFF}}."
wikitext
text/x-wiki
[[Abilities]] in {{BFF}}.
ffb5b26c014e453bf5d766e2b1ebcdfaf27c1ad9
File:Scanner.png
6
582
923
2025-08-21T20:52:24Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|game}}
5fdc0517c60eec1aa02a1fef9763fa88c38be9ad
929
923
2025-08-21T20:58:57Z
Sharparam
284703
Add game image template
wikitext
text/x-wiki
{{Game image}}
== Licensing ==
{{License|game}}
3270ce19f01542118cc5c866db430fc73423612a
Template:File other
10
583
924
2025-08-21T20:54:17Z
Sharparam
284703
Created page with "{{#switch: <!--If no or empty "demospace" parameter then detect namespace--> {{#if:{{{demospace|}}} | {{lc: {{{demospace}}} }} <!--Use lower case "demospace"--> | {{#ifeq:{{NAMESPACE}}|{{ns:6}} | file | other }} }} | file | image = {{{1|}}} | other | #default = {{{2|}}} }}<!--End switch--><noinclude> {{Documentation}} <!-- Add categories and interwikis to the /doc subpage, not here! --> </noinclude>"
wikitext
text/x-wiki
{{#switch:
<!--If no or empty "demospace" parameter then detect namespace-->
{{#if:{{{demospace|}}}
| {{lc: {{{demospace}}} }} <!--Use lower case "demospace"-->
| {{#ifeq:{{NAMESPACE}}|{{ns:6}}
| file
| other
}}
}}
| file
| image = {{{1|}}}
| other
| #default = {{{2|}}}
}}<!--End switch--><noinclude>
{{Documentation}}
<!-- Add categories and interwikis to the /doc subpage, not here! -->
</noinclude>
0ae5bdb15fbe55f5787d00f85a443e4eac787c5e
Template:File other/doc
10
584
925
2025-08-21T20:55:18Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Namespace manipulation templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Namespace manipulation templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
0db4fcf6efd8e3996b46bb02dce919df6124f748
Template:Game image
10
585
926
2025-08-21T20:55:42Z
Sharparam
284703
Created page with "<includeonly>{{File other|[[Category:Game images]]}}</includeonly><noinclude> {{Documentation}} </noinclude>"
wikitext
text/x-wiki
<includeonly>{{File other|[[Category:Game images]]}}</includeonly><noinclude>
{{Documentation}}
</noinclude>
c78a04923d00959be766f2908911a29b71cc1209
Template:Game image/doc
10
586
927
2025-08-21T20:57:55Z
Sharparam
284703
Created page with "Use on files that are images exported from the game. Places the file in the [[:Category:Game images|game images]] category. == Usage == {{Tlx|Game image}} <includeonly>{{Sandbox other||[[Category:File templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
Use on files that are images exported from the game. Places the file in the [[:Category:Game images|game images]] category.
== Usage ==
{{Tlx|Game image}}
<includeonly>{{Sandbox other||[[Category:File templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
943ab5144b7869a9247c146638e1335b709d6c1f
Category:File templates
14
587
928
2025-08-21T20:58:16Z
Sharparam
284703
Created page with "Templates to help work with or categorise files."
wikitext
text/x-wiki
Templates to help work with or categorise files.
f23108893b2522f523cb55d4a4a4bfa79744cca6
Category:Game images
14
588
930
2025-08-21T20:59:29Z
Sharparam
284703
Created page with "Images extracted from the game files. Use the {{tl|Game image}} template to place files into this category."
wikitext
text/x-wiki
Images extracted from the game files. Use the {{tl|Game image}} template to place files into this category.
912de8fa5fb07765ad87496f457aaa1eacc6b8f9
931
930
2025-08-21T20:59:51Z
Sharparam
284703
Add parent category
wikitext
text/x-wiki
Images extracted from the game files. Use the {{tl|Game image}} template to place files into this category.
[[Category:Game assets]]
b72293034ec9442cf0a59178bb392cd2dc85c4f9
Category:Game assets
14
589
932
2025-08-21T21:00:34Z
Sharparam
284703
Created page with "Assets/files that have been sourced directly from the game files of {{BFF}}."
wikitext
text/x-wiki
Assets/files that have been sourced directly from the game files of {{BFF}}.
c36e430ebb51e2f3a5bb681e61f314fde5047b1a
933
932
2025-08-21T21:00:57Z
Sharparam
284703
Add template instruction
wikitext
text/x-wiki
Assets/files that have been sourced directly from the game files of {{BFF}}. Use the {{tl|Game asset}} template to place files into this category.
266793c2d375aa979be2e77e4ce56c927328281d
Template:Game asset
10
590
934
2025-08-21T21:01:25Z
Sharparam
284703
Created page with "<includeonly>{{File other|[[Category:Game assets]]}}</includeonly> <noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{File other|[[Category:Game assets]]}}</includeonly>
<noinclude>{{Documentation}}</noinclude>
1a4fad2b6dfc8a0d60ebdbe1b0d46e89842c5b99
Template:Game asset/doc
10
591
935
2025-08-21T21:02:51Z
Sharparam
284703
Created page with "Template to place files into the [[:Category:Game assets|game assets]] category. If the file is an image or audio file, use {{tl|Game image}} or {{tl|Game audio}} instead, respectively. == Usage == {{tlx|Game asset}} <includeonly>{{Sandbox other||[[Category:File templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
Template to place files into the [[:Category:Game assets|game assets]] category.
If the file is an image or audio file, use {{tl|Game image}} or {{tl|Game audio}} instead, respectively.
== Usage ==
{{tlx|Game asset}}
<includeonly>{{Sandbox other||[[Category:File templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
6d2473959585275d27b6bd903f738e328c8d53a2
Template:Game audio
10
592
936
2025-08-21T21:03:24Z
Sharparam
284703
Created page with "<includeonly>{{File other|[[Category:Game audio]]}}</includeonly> <noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{File other|[[Category:Game audio]]}}</includeonly>
<noinclude>{{Documentation}}</noinclude>
78524f1842114d188967471f6571bdb2f0359cae
Template:Game audio/doc
10
593
937
2025-08-21T21:04:11Z
Sharparam
284703
Created page with "Places files into the [[:Category:Game audio|game audio]] category. == Usage == {{tlx|Game audio}} <includeonly>{{Sandbox other||[[Category:File templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
Places files into the [[:Category:Game audio|game audio]] category.
== Usage ==
{{tlx|Game audio}}
<includeonly>{{Sandbox other||[[Category:File templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
d575cc599795375aaa040ff4b63e265bdd18bc57
Category:Game audio
14
594
938
2025-08-21T21:04:40Z
Sharparam
284703
Created page with "Audio files that have been extracted from the game files of {{BFF}}. Place files into this category by using the {{tl|Game audio}} template. [[Category:Game assets]]"
wikitext
text/x-wiki
Audio files that have been extracted from the game files of {{BFF}}. Place files into this category by using the {{tl|Game audio}} template.
[[Category:Game assets]]
1f7a2e55596868ce0dc93944e9b7eee2792f96ba
File:Katanas.png
6
595
939
2025-08-21T21:06:16Z
Sharparam
284703
{{Game image}}
wikitext
text/x-wiki
== Summary ==
{{Game image}}
== Licensing ==
{{License|game}}
e84980f43421c792e6f1c8e1312cd5fa11b6864e
File:Sharp outlined.png
6
596
940
2025-08-21T21:07:44Z
Sharparam
284703
Modified version of the icon from the game files to add a black outline.
wikitext
text/x-wiki
== Summary ==
Modified version of the icon from the game files to add a black outline.
== Licensing ==
{{License|game}}
d8df869b47897c8edf3e2084037876caca074149
File:Blunt outlined.png
6
597
941
2025-08-21T21:08:57Z
Sharparam
284703
Modified version of the icon from the game files to add a black outline.
wikitext
text/x-wiki
== Summary ==
Modified version of the icon from the game files to add a black outline.
== Licensing ==
{{License|game}}
d8df869b47897c8edf3e2084037876caca074149
File:Technomancy outlined.png
6
598
942
2025-08-21T21:09:12Z
Sharparam
284703
Modified version of the icon from the game files to add a black outline.
wikitext
text/x-wiki
== Summary ==
Modified version of the icon from the game files to add a black outline.
== Licensing ==
{{License|game}}
d8df869b47897c8edf3e2084037876caca074149
File:Sharp.png
6
599
943
2025-08-21T21:09:46Z
Sharparam
284703
{{Game image}}
wikitext
text/x-wiki
== Summary ==
{{Game image}}
== Licensing ==
{{License|game}}
e84980f43421c792e6f1c8e1312cd5fa11b6864e
File:Blunt.png
6
600
944
2025-08-21T21:10:08Z
Sharparam
284703
{{Game image}}
wikitext
text/x-wiki
== Summary ==
{{Game image}}
== Licensing ==
{{License|game}}
e84980f43421c792e6f1c8e1312cd5fa11b6864e
File:Technomancy.png
6
601
945
2025-08-21T21:10:26Z
Sharparam
284703
{{Game image}}
wikitext
text/x-wiki
== Summary ==
{{Game image}}
== Licensing ==
{{License|game}}
e84980f43421c792e6f1c8e1312cd5fa11b6864e
File:Uranopolis (Tower Complex).png
6
602
946
2025-08-21T21:14:25Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Uranopolis_Entrance.png
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Uranopolis_Entrance.png
}}
== Licensing ==
{{License|game}}
fb338377a1c6697787483e018e773b122f2b82dd
File:Uranopolis (Lone Tower).png
6
603
947
2025-08-21T21:15:15Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Uranopolis_LoneTower.png
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Uranopolis_LoneTower.png
}}
== Licensing ==
{{License|game}}
f379939b05f5531092f6cb5c5da18ed46af2958b
Uranopolis
0
352
948
467
2025-08-21T21:15:46Z
Sharparam
284703
Fix second sub-location todo
wikitext
text/x-wiki
'''Uranopolis''' is a location in {{BFF}}.
== Sub-locations ==
Uranopolis consists of two sub-locations: Tower Complex and Lone Tower.
=== Tower Complex ===
{{Main|Uranopolis/Tower Complex}}
[[File:Uranopolis (Tower Complex).png|thumb|The tower complex as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Tower Complex area.]]
The '''Tower Complex''' is the first sub-location encountered by the player.
{{clear}}
=== Lone Tower ===
[[File:Uranopolis (Lone Tower).png|thumb|The lone tower as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Lone Tower area. The towers housing the area's boss as well as the recalibration "eye" can be seen.]]
The '''Lone Tower''' is the second sub-location encountered by the player. The area's boss – [[Nurgei the Blademaster]] – can be found here.
{{Navbox/Locations}}
[[Category:Locations]]
c3a53919ad49c80b8ca6ecf37e88e385e707727b
File:Monastery (Lower).png
6
604
949
2025-08-21T21:16:47Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Monasatery_Bridge.png
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Monasatery_Bridge.png
}}
== Licensing ==
{{License|game}}
2a25eca089eb36a086905fe8b30501e05598829b
File:Monastery (Upper).png
6
605
950
2025-08-21T21:17:30Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Monastery_Upper.png
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Monastery_Upper.png
}}
== Licensing ==
{{License|game}}
07f3467b9dd417d832f5d06d38aa7630d48e8745
Category:Locations
14
606
951
2025-08-21T21:18:52Z
Sharparam
284703
Created page with "[[Locations]] in {{BFF}}."
wikitext
text/x-wiki
[[Locations]] in {{BFF}}.
abf5a13f9593d93b2f288c96a230460de31f1da2
Locations
0
351
952
465
2025-08-21T21:19:09Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{Navbox/Locations}}
[[Category:Locations]]
867a4bbec1bc92e57b6daf306356c7fd1fee46af
Template:Sic
10
607
953
2025-08-21T21:19:23Z
Sharparam
284703
Created page with "<!-- Display the first two default parameters unless ? -->{{#ifeq:{{{1|?}}}|?|{{{2|}}}{{{3|}}}|{{{1|}}}{{{2|}}}}}<!-- Display options for [sic] linked, unlinked(default) or hidden. -->{{#if:{{{hide|}}}|| [''{{#if:{{{nolink|}}}|sic|[[sic]]}}{{#ifeq:{{{1|}}}|?|?}}'']}}<!-- Categorisation options. Currently disabled - see [[Help talk:CS1 errors/Archive 1#%7B%7Bsic%7C?%7Cnolink=y%7D%7D]] --><!--{{#ifeq:{{{1|}}}|?|{{#if:{{NAMESPACE}}||Category:Articles..."
wikitext
text/x-wiki
<!--
Display the first two default parameters unless ?
-->{{#ifeq:{{{1|?}}}|?|{{{2|}}}{{{3|}}}|{{{1|}}}{{{2|}}}}}<!--
Display options for [sic] linked, unlinked(default) or hidden.
-->{{#if:{{{hide|}}}|| [''{{#if:{{{nolink|}}}|sic|[[sic]]}}{{#ifeq:{{{1|}}}|?|?}}'']}}<!--
Categorisation options. Currently disabled - see [[Help talk:CS1 errors/Archive 1#%7B%7Bsic%7C?%7Cnolink=y%7D%7D]]
--><!--{{#ifeq:{{{1|}}}|?|{{#if:{{NAMESPACE}}||[[Category:Articles containing possible transcription errors]]}}}}--><noinclude>
{{documentation}}
</noinclude>
ca36b46c4c83b9a5c2bd1e9028abaeb475e53018
954
953
2025-08-21T21:19:55Z
Sharparam
284703
Fix link to sic on WP
wikitext
text/x-wiki
<!--
Display the first two default parameters unless ?
-->{{#ifeq:{{{1|?}}}|?|{{{2|}}}{{{3|}}}|{{{1|}}}{{{2|}}}}}<!--
Display options for [sic] linked, unlinked(default) or hidden.
-->{{#if:{{{hide|}}}|| [''{{#if:{{{nolink|}}}|sic|[[wikipedia:sic]]}}{{#ifeq:{{{1|}}}|?|?}}'']}}<!--
Categorisation options. Currently disabled - see [[Help talk:CS1 errors/Archive 1#%7B%7Bsic%7C?%7Cnolink=y%7D%7D]]
--><!--{{#ifeq:{{{1|}}}|?|{{#if:{{NAMESPACE}}||[[Category:Articles containing possible transcription errors]]}}}}--><noinclude>
{{documentation}}
</noinclude>
f4a1d499c2aee37410d1b095a38a7cb8d7bf948a
955
954
2025-08-21T21:20:10Z
Sharparam
284703
Fix sic link showing interwiki prefix
wikitext
text/x-wiki
<!--
Display the first two default parameters unless ?
-->{{#ifeq:{{{1|?}}}|?|{{{2|}}}{{{3|}}}|{{{1|}}}{{{2|}}}}}<!--
Display options for [sic] linked, unlinked(default) or hidden.
-->{{#if:{{{hide|}}}|| [''{{#if:{{{nolink|}}}|sic|[[wikipedia:sic|sic]]}}{{#ifeq:{{{1|}}}|?|?}}'']}}<!--
Categorisation options. Currently disabled - see [[Help talk:CS1 errors/Archive 1#%7B%7Bsic%7C?%7Cnolink=y%7D%7D]]
--><!--{{#ifeq:{{{1|}}}|?|{{#if:{{NAMESPACE}}||[[Category:Articles containing possible transcription errors]]}}}}--><noinclude>
{{documentation}}
</noinclude>
122173e063529ad4cdba860981e6080c8105c537
Template:Sic/doc
10
608
956
2025-08-21T21:21:27Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Template:Sic|Template and documentation on Wikipedia]] <includeonly>{{Sandbox other||[[Category:Inline templates]][[Category:Typing-aid templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Template:Sic|Template and documentation on Wikipedia]]
<includeonly>{{Sandbox other||[[Category:Inline templates]][[Category:Typing-aid templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
50e8c0b6c03f834f0c33ead4b4688565c98ce30e
Category:Inline templates
14
609
957
2025-08-21T21:21:46Z
Sharparam
284703
Created page with "Templates that can/should be used inline."
wikitext
text/x-wiki
Templates that can/should be used inline.
2b990a2df2dd087ebac8b1f311d1752d5b47b3fa
MediaWiki:Sidebar
8
324
958
418
2025-08-21T21:26:50Z
Sharparam
284703
Add useful links to sidebar
wikitext
text/x-wiki
* navigation
** mainpage|mainpage-description
** recentchanges-url|recentchanges
** Special:NewFiles|New files
** randompage-url|randompage
* Bleak Faith
** Items
** Locations
** NPCs
** Enemies
** Bosses
* sidebar-customizing-wiki
** MediaWiki:Sidebar|sidebar-edit-sidebar
** MediaWiki:Common.css|sidebar-edit-common-css
** MediaWiki:Vector.css|sidebar-edit-vector-css
** MediaWiki:Common.js|sidebar-edit-common-js
** Special:Gadgets|sidebar-gadgets
** Special:Import|sidebar-special-import
** Special:Export|sidebar-special-export
** Special:AllPages|sidebar-all-pages
** Special:SpecialPages|sidebar-special-pages
* wiki.gg
** support:|sidebar-support-wiki
** Wikigg-ticket-link|sidebar-submit-ticket
** wikigg-socialmedia-joinlink|wikigg-socialmedia-jointext-sidebar
728fcc8f8362af28c1f933fc508a2334547f135a
File:Blok 6147.png
6
610
959
2025-08-21T21:28:04Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Blok.png
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Blok.png
}}
== Licensing ==
{{License|game}}
9839db94437e0e25d6cc026c5150e038d2f724c2
Homunculus
0
611
960
2025-08-21T21:28:36Z
Sharparam
284703
Created page with "'''Homunculi''' in {{BFF}} exist as objects in the world and [[items]] the player can use. == Overview == The homunculi found in the world are used to teleport between locations, and can also be rested at to recover resources and respawn [[enemies]]. The player can also use the [[Homunculus Mirage]] item to spawn their own homunculus in a location of their choosing (with some restrictions). == List of homunculi == {| class="wikitable" ! [[Locations|Location]] !! Des..."
wikitext
text/x-wiki
'''Homunculi''' in {{BFF}} exist as objects in the world and [[items]] the player can use.
== Overview ==
The homunculi found in the world are used to teleport between locations, and can also be rested at to recover resources and respawn [[enemies]].
The player can also use the [[Homunculus Mirage]] item to spawn their own homunculus in a location of their choosing (with some restrictions).
== List of homunculi ==
{| class="wikitable"
! [[Locations|Location]] !! Description !! Coordinates
|-
| [[Monastery#Lower|Monastery (Lower)]] || Located on the side of the long roof. In [[New Game Plus]], [[The Handler]] will be standing nearby. || {{coords|22057.55|-89678.87|-15425.86}}
|-
| [[Monastery#Upper|Monastery (Upper)]] || Located just outside the monastery at the top of the area, near [[Konrad the Traitor|Konrad the Traitor's]] boss arena. || {{coords|15413.84|-43467.14|-811.55}}
|-
| [[Blok 6147]] || Located in the center of the circular structures, [[The Handler]] can be found next to it. || {{coords|0|0|1156.54}}
|-
| [[Deluge]] || Located at the top of the shaft lined with stairs after entering the area, [[The Handler]] can be found sitting on a ledge nearby. || {{coords|-3185|-7374|5624}}
|-
| [[Ghost Town#Floor 13|Ghost Town (Floor 13)]] || After exiting the elevator, walk down the path and the homunculus will be in an opening on the left. || {{coords|1129|-9050|2199}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || After taking the elevator down from the Floor 13 area, the homunculus will be straight ahead. [[The Handler]] can be found standing to the side of the nearby doorway. || {{coords|1057|-8281|164}}
|-
| [[Machinarium]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead to the left. || {{coords|-2578.36|25970.67|-12004.39}}
|-
| [[Desert]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead below a torch. || {{coords|-9387.86|64791.21|-136368.03}}
|-
| [[Desert Mirage]] || Located straight ahead after entering the teleportation orb. || {{coords|278493.06|-61587.78|-119471.95}}
|-
| [[Anomaly]] || Located on the right after entering the area. [[The Handler]] is standing just ahead, in front of some pillars. || {{coords|47122.91|160919.88|-142106.30}}
|-
| [[Vermillion Fields#Plaza|Vermillion Fields (Plaza)]] || Located in the center of the circular structure, mirroring its location in [[Blok 6147]]. || {{coords|517|-5000|1170}}
|-
| rowspan="3" | [[Vermillion Fields#Temple|Vermillion Fields (Temple)]]{{note|name=temple}}
| Located in a cave after leaving the Plaza area. || {{coords|-26|-5352|2725}}
|-
| After operating a lever in the building on the cliffs, keep going through the area. Eventually you will reach a big circular room and notice a Homunculus in the middle of a bridge. This is the same "Temple" Homunculus as before, but operating the lever has moved it upwards. || {{coords|-58.7|-5351|8264}}
|-
| After operating the second lever near where the second bald knight is after the second homunculus position, the homunculus moves to its final position at the top of the tower. || {{coords|-26.9|-5351|1685}}
|}
== Notes ==
{{notelist|refs=
{{note|name=temple|The homunculus in Vermillion Fields temple moves between the three locations by operating levers.}}
}}
== External links ==
* [[w:Homunculus|Homunculus on Wikipedia]]
a2232f7ee4c2f2293347db7ee209a477b56b6bb4
975
960
2025-08-21T21:33:46Z
Sharparam
284703
Fix link to Wikipedia
wikitext
text/x-wiki
'''Homunculi''' in {{BFF}} exist as objects in the world and [[items]] the player can use.
== Overview ==
The homunculi found in the world are used to teleport between locations, and can also be rested at to recover resources and respawn [[enemies]].
The player can also use the [[Homunculus Mirage]] item to spawn their own homunculus in a location of their choosing (with some restrictions).
== List of homunculi ==
{| class="wikitable"
! [[Locations|Location]] !! Description !! Coordinates
|-
| [[Monastery#Lower|Monastery (Lower)]] || Located on the side of the long roof. In [[New Game Plus]], [[The Handler]] will be standing nearby. || {{coords|22057.55|-89678.87|-15425.86}}
|-
| [[Monastery#Upper|Monastery (Upper)]] || Located just outside the monastery at the top of the area, near [[Konrad the Traitor|Konrad the Traitor's]] boss arena. || {{coords|15413.84|-43467.14|-811.55}}
|-
| [[Blok 6147]] || Located in the center of the circular structures, [[The Handler]] can be found next to it. || {{coords|0|0|1156.54}}
|-
| [[Deluge]] || Located at the top of the shaft lined with stairs after entering the area, [[The Handler]] can be found sitting on a ledge nearby. || {{coords|-3185|-7374|5624}}
|-
| [[Ghost Town#Floor 13|Ghost Town (Floor 13)]] || After exiting the elevator, walk down the path and the homunculus will be in an opening on the left. || {{coords|1129|-9050|2199}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || After taking the elevator down from the Floor 13 area, the homunculus will be straight ahead. [[The Handler]] can be found standing to the side of the nearby doorway. || {{coords|1057|-8281|164}}
|-
| [[Machinarium]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead to the left. || {{coords|-2578.36|25970.67|-12004.39}}
|-
| [[Desert]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead below a torch. || {{coords|-9387.86|64791.21|-136368.03}}
|-
| [[Desert Mirage]] || Located straight ahead after entering the teleportation orb. || {{coords|278493.06|-61587.78|-119471.95}}
|-
| [[Anomaly]] || Located on the right after entering the area. [[The Handler]] is standing just ahead, in front of some pillars. || {{coords|47122.91|160919.88|-142106.30}}
|-
| [[Vermillion Fields#Plaza|Vermillion Fields (Plaza)]] || Located in the center of the circular structure, mirroring its location in [[Blok 6147]]. || {{coords|517|-5000|1170}}
|-
| rowspan="3" | [[Vermillion Fields#Temple|Vermillion Fields (Temple)]]{{note|name=temple}}
| Located in a cave after leaving the Plaza area. || {{coords|-26|-5352|2725}}
|-
| After operating a lever in the building on the cliffs, keep going through the area. Eventually you will reach a big circular room and notice a Homunculus in the middle of a bridge. This is the same "Temple" Homunculus as before, but operating the lever has moved it upwards. || {{coords|-58.7|-5351|8264}}
|-
| After operating the second lever near where the second bald knight is after the second homunculus position, the homunculus moves to its final position at the top of the tower. || {{coords|-26.9|-5351|1685}}
|}
== Notes ==
{{notelist|refs=
{{note|name=temple|The homunculus in Vermillion Fields temple moves between the three locations by operating levers.}}
}}
== External links ==
* [[wikipedia:Homunculus|Homunculus on Wikipedia]]
829f2024ba392d81a9d14c59df992c329ac23b2d
Template:Notelist
10
612
962
961
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{safesubst<noinclude />:Reflist|{{{1|{{{colwidth|}}}}}}|refs={{{refs|{{{notes|}}}}}}|group={{safesubst<noinclude />:#switch:{{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}}}{{safesubst<noinclude />:#invoke:Check for unknown parameters|check|unknown={{Main other|[[Category:Pages using notelist with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Notelist]] with unknown parameter "_VALUE_"|ignoreblank=y| 1 | colwidth | group | notes | refs }}<noinclude>
{{Documentation}}</noinclude>
94f17b894235ff18c73072096f5940cdbcc5b719
Template:Reflist
10
613
964
963
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<templatestyles src="Reflist/styles.css" /><div class="reflist<!--
-->{{#if:{{{1|}}}{{{colwidth|}}}| reflist-columns references-column-width}} {{#switch:{{{liststyle|{{{group|}}}}}}
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = reflist-{{{liststyle|{{{group}}}}}}
}}" <!-- End class, start style -->{{#if:{{{1|}}}
| {{#iferror:{{#ifexpr: {{{1|1}}} > 1 }} |style="column-width: {{{1}}};"}}
| {{#if: {{{colwidth|}}}|style="column-width: {{{colwidth}}};"}}
}}>
{{#tag:references|{{{refs|}}}|group={{{group|}}}|responsive={{#if:{{{1|}}}{{{colwidth|}}}|0|1}}}}</div>{{#invoke:Check for unknown parameters|check|unknown={{main other|[[Category:Pages using reflist with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Reflist]] with unknown parameter "_VALUE_"|ignoreblank=y| 1 | colwidth | group | liststyle | refs }}<noinclude>
{{Documentation}}</noinclude>
5865246773ff390ed5700866ea2396d78a81b01f
Module:Check for unknown parameters
828
614
966
965
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- This module may be used to compare the arguments passed to the parent
-- with a list of arguments, returning a specified result if an argument is
-- not on the list
local p = {}
local function trim(s)
return s:match('^%s*(.-)%s*$')
end
local function isnotempty(s)
return s and trim(s) ~= ''
end
function p.check (frame)
local args = frame.args
local pargs = frame:getParent().args
local ignoreblank = isnotempty(frame.args['ignoreblank'])
local checkpos = isnotempty(frame.args['checkpositional'])
local knownargs = {}
local unknown = frame.args['unknown'] or 'Found _VALUE_, '
local preview = frame.args['preview']
local res = {}
local regexps = {}
local comments = {}
local commentstr = ''
local ispreview = frame:preprocess( "{{REVISIONID}}" ) == "" and 1 or 0
-- create the list of known args, regular expressions, and the return string
for k, v in pairs(args) do
if type(k) == 'number' then
v = trim(v)
knownargs[v] = 1
elseif k:find('^regexp[1-9][0-9]*$') then
table.insert(regexps, '^' .. v .. '$')
end
end
if isnotempty(preview) then
preview = '<div class="hatnote" style="color:red"><strong>Warning:</strong> ' .. preview .. ' (this message is shown only in preview).</div>'
elseif preview == nil then
preview = unknown
end
if ispreview == 1 then
unknown = preview
ignoreblank = false
end
-- adds one result to the output tables
local function addresult(k)
if k == '' then
-- Fix odd bug for | = which gets stripped to the empty string and
-- breaks category links
k = ' '
end
local r = unknown:gsub('_VALUE_', k)
table.insert(res, r)
table.insert(comments, '"' .. k .. '"')
end
-- loop over the parent args, and make sure they are on the list
for k, v in pairs(pargs) do
if type(k) == 'string' and knownargs[k] == nil then
local knownflag = false
for i, regexp in ipairs(regexps) do
if mw.ustring.match(k, regexp) then
knownflag = true
break
end
end
if not knownflag and ( not ignoreblank or isnotempty(v) ) then
k = mw.ustring.gsub(k, '[^%w%-_ ]', '?')
addresult(k)
end
elseif checkpos and
type(k) == 'number' and
knownargs[tostring(k)] == nil and
( not ignoreblank or isnotempty(v) )
then
addresult(k)
end
end
if #comments > 0 then
commentstr = '<!-- Module:Check for unknown parameters results: ' ..
table.concat(comments, ', ') .. '-->'
end
return table.concat(res) .. commentstr
end
return p
90cb45a6cbe02f0d73cbfdec8233df899b000e3d
Template:Note
10
615
968
967
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#if:{{{name|}}}
|{{#tag:ref|{{{1|{{{reference|{{{content|{{{text|}}}}}}}}}}}}|name={{{name|}}}|group={{#switch: {{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}
}}
|{{#tag:ref|{{{1|{{{reference|{{{content|{{{text|}}}}}}}}}}}}|group={{#switch: {{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}
}}
}}</includeonly><noinclude>
{{documentation}}
</noinclude>
6ed4e5c148014b92a23bd51d16f3180881bb876c
Template:Reflist/styles.css
10
616
970
969
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
.reflist {
list-style-type: decimal;
margin-bottom: 0.5em;
}
@media screen {
.reflist {
font-size: 0.9em; /* Make default font smaller only on screens. */
}
}
.reflist .references {
font-size: 1em; /* Reset font size when nested in reflist. */
list-style-type: inherit; /* Enable custom list-style types. */
margin-bottom: 0; /* Avoid double margin when nested in reflist. */
}
.reflist-columns {
margin-top: 0.3em; /* Reset top margin for column-embedded lists. */
}
.reflist-columns ol {
margin-top: 0;
}
.reflist-columns li {
break-inside: avoid-column; /* Avoid elements breaking between columns. */
}
.reflist-upper-alpha {
list-style-type: upper-alpha;
}
.reflist-upper-roman {
list-style-type: upper-roman;
}
.reflist-lower-alpha {
list-style-type: lower-alpha;
}
.reflist-lower-greek {
list-style-type: lower-greek;
}
.reflist-lower-roman {
list-style-type: lower-roman;
}
e2f766e5d4d3ee66aca32f6714fef1bc97648e0a
Template:Ref
10
617
972
971
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{#if:{{{follow|}}}|{{#tag:ref|{{{1|{{{refn|}}}}}}|group={{{group|}}}|follow={{{follow|}}}}}|{{#if:{{{name|}}}|{{#tag:ref|{{{1|{{{refn|}}}}}}|name={{{name|}}}|group={{{group|}}}}}|{{#tag:ref|{{{1|{{{refn|}}}}}}|group={{{group|}}}}}}}}}</includeonly><noinclude>{{documentation}}</noinclude>
9fd4ba12eab57eadfed1197d60df81947547d276
MediaWiki:Cite link label group-lower-alpha
8
618
974
973
2025-08-21T21:32:27Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
a b c d e f g h i j k l m n o p q r s t u v w x y z aa ab ac ad ae af ag ah ai aj ak al am an ao ap aq ar as at au av aw ax ay az ba bb bc bd be bf bg bh bi bj bk bl bm bn bo bp bq br bs bt bu bv bw bx by bz ca cb cc cd ce cf cg ch ci cj ck cl cm cn co cp cq cr cs ct cu cv cw cx cy cz da db dc dd de df dg dh di dj dk dl dm dn do dp dq dr ds dt du dv dw dx dy dz ea eb ec ed ee ef eg eh ei ej ek el em en eo ep eq er es et eu ev ew ex ey ez fa fb fc fd fe ff fg fh fi fj fk fl fm fn fo fp fq fr fs ft fu fv fw fx fy fz ga gb gc gd ge gf gg gh gi gj gk gl gm gn go gp gq gr gs gt gu gv gw gx gy gz ha hb hc hd he hf hg hh hi hj hk hl hm hn ho hp hq hr hs ht hu hv hw hx hy hz ia ib ic id ie if ig ih ii ij ik il im in io ip iq ir is it iu iv iw ix iy iz ja jb jc jd je jf jg jh ji jj jk jl jm jn jo jp jq jr js jt ju jv jw jx jy jz ka kb kc kd ke kf kg kh ki kj kk kl km kn ko kp kq kr ks kt ku kv kw kx ky kz la lb lc ld le lf lg lh li lj lk ll lm ln lo lp lq lr ls lt lu lv lw lx ly lz ma mb mc md me mf mg mh mi mj mk ml mm mn mo mp mq mr ms mt mu mv mw mx my mz na nb nc nd ne nf ng nh ni nj nk nl nm nn no np nq nr ns nt nu nv nw nx ny nz oa ob oc od oe of og oh oi oj ok ol om on oo op oq or os ot ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj pk pl pm pn po pp pq pr ps pt pu pv pw px py pz qa qb qc qd qe qf qg qh qi qj qk ql qm qn qo qp qq qr qs qt qu qv qw qx qy qz ra rb rc rd re rf rg rh ri rj rk rl rm rn ro rp rq rr rs rt ru rv rw rx ry rz sa sb sc sd se sf sg sh si sj sk sl sm sn so sp sq sr ss st su sv sw sx sy sz ta tb tc td te tf tg th ti tj tk tl tm tn to tp tq tr ts tt tu tv tw tx ty tz ua ub uc ud ue uf ug uh ui uj uk ul um un uo up uq ur us ut uu uv uw ux uy uz va vb vc vd ve vf vg vh vi vj vk vl vm vn vo vp vq vr vs vt vu vv vw vx vy vz wa wb wc wd we wf wg wh wi wj wk wl wm wn wo wp wq wr ws wt wu wv ww wx wy wz xa xb xc xd xe xf xg xh xi xj xk xl xm xn xo xp xq xr xs xt xu xv xw xx xy xz ya yb yc yd ye yf yg yh yi yj yk yl ym yn yo yp yq yr ys yt yu yv yw yx yy yz za zb zc zd ze zf zg zh zi zj zk zl zm zn zo zp zq zr zs zt zu zv zw zx zy zz aaa aab aac aad aae aaf aag aah aai aaj aak aal aam aan aao aap aaq aar aas aat aau aav aaw aax aay aaz aba abb abc abd abe abf abg abh abi abj abk abl abm abn abo abp abq abr abs abt abu abv abw abx aby abz aca acb acc acd ace acf acg ach aci acj ack acl acm acn aco acp acq acr acs act acu acv acw acx acy acz ada adb adc add ade adf adg adh adi adj adk adl adm adn ado adp adq adr ads adt adu adv adw adx ady adz aea aeb aec aed aee aef aeg aeh aei aej aek ael aem aen aeo aep aeq aer aes aet aeu aev aew aex aey aez afa afb afc afd afe aff afg afh afi afj afk afl afm afn afo afp afq afr afs aft afu afv afw afx afy afz aga agb agc agd age agf agg agh agi agj agk agl agm agn ago agp agq agr ags agt agu agv agw agx agy agz aha ahb ahc ahd ahe ahf ahg ahh ahi ahj ahk ahl ahm ahn aho ahp ahq ahr ahs aht ahu ahv ahw ahx ahy ahz aia aib aic aid aie aif aig aih aii aij aik ail aim ain aio aip aiq air ais ait aiu aiv aiw aix aiy aiz aja ajb ajc ajd aje ajf ajg ajh aji ajj ajk ajl ajm ajn ajo ajp ajq ajr ajs ajt aju ajv ajw ajx ajy ajz aka akb akc akd ake akf akg akh aki akj akk akl akm akn ako akp akq akr aks akt aku akv akw akx aky akz ala alb alc ald ale alf alg alh ali alj alk all alm aln alo alp alq alr als alt alu alv alw alx aly alz ama amb amc amd ame amf amg amh ami amj amk aml amm amn amo amp amq amr ams amt amu amv amw amx amy amz ana anb anc and ane anf ang anh ani anj ank anl anm ann ano anp anq anr ans ant anu anv anw anx any anz aoa aob aoc aod aoe aof aog aoh aoi aoj aok aol aom aon aoo aop aoq aor aos aot aou aov aow aox aoy aoz apa apb apc apd ape apf apg aph api apj apk apl apm apn apo app apq apr aps apt apu apv apw apx apy apz aqa aqb aqc aqd aqe aqf aqg aqh aqi aqj aqk aql aqm aqn aqo aqp aqq aqr aqs aqt aqu aqv aqw aqx aqy aqz ara arb arc ard are arf arg arh ari arj ark arl arm arn aro arp arq arr ars art aru arv arw arx ary arz asa asb asc asd ase asf asg ash asi asj ask asl asm asn aso asp asq asr ass ast asu asv asw asx asy asz ata atb atc atd ate atf atg ath ati atj atk atl atm atn ato atp atq atr ats att atu atv atw atx aty atz aua aub auc aud aue auf aug auh aui auj auk aul aum aun auo aup auq aur aus aut auu auv auw aux auy auz ava avb avc avd ave avf avg avh avi avj avk avl avm avn avo avp avq avr avs avt avu avv avw avx avy avz awa awb awc awd awe awf awg awh awi awj awk awl awm awn awo awp awq awr aws awt awu awv aww awx awy awz axa axb axc axd axe axf axg axh axi axj axk axl axm axn axo axp axq axr axs axt axu axv axw axx axy axz aya ayb ayc ayd aye ayf ayg ayh ayi ayj ayk ayl aym ayn ayo ayp ayq ayr ays ayt ayu ayv ayw ayx ayy ayz aza azb azc azd aze azf azg azh azi azj azk azl azm azn azo azp azq azr azs azt azu azv azw azx azy azz
b49c822b47338613f0c10a02bd4f6a2a6735e324
New Game Plus
0
619
976
2025-08-21T21:35:35Z
Sharparam
284703
Created page with "{{stub}} '''{{PAGENAME}}''', also known as '''New Game+''' or '''NG+''', is the option to restart the game after beating it to keep using the same character while increasing the difficulty and the max [[level]] cap. == Overview == There is no limit to how many times the player can restart the game, but there will be no further changes after the third iteration (NG+++, or NG+3). == Changes == === Max [[level]] === Each time a new iteration is started, the max level ca..."
wikitext
text/x-wiki
{{stub}}
'''{{PAGENAME}}''', also known as '''New Game+''' or '''NG+''', is the option to restart the game after beating it to keep using the same character while increasing the difficulty and the max [[level]] cap.
== Overview ==
There is no limit to how many times the player can restart the game, but there will be no further changes after the third iteration (NG+++, or NG+3).
== Changes ==
=== Max [[level]] ===
Each time a new iteration is started, the max level cap is increased by 5, until NG+3. After the third restart, the level cap stays the same. This means the maximum possible level that can be attained is 40 (25 from the base game, with an additional 5 from each NG+ iteration up to NG+3).
{| class="wikitable mw-collapsible mw-collapsed" style="text-align: right;"
! scope="col" | New Game
! scope="col" | Max level
|-
| 0 || 25
|-
| 1 || 30
|-
| 2 || 35
|-
| 3 || 40
|}
=== The Handler ===
In NG+, [[The Handler]] has an additional location near the first [[Homunculus]] in the [[Monastery#Lower|lower Monastery]].
f120a3e05824c1bb6685e05cbeb802dbfab0ea8d
977
976
2025-08-21T21:35:52Z
Sharparam
284703
Add category
wikitext
text/x-wiki
{{stub}}
'''{{PAGENAME}}''', also known as '''New Game+''' or '''NG+''', is the option to restart the game after beating it to keep using the same character while increasing the difficulty and the max [[level]] cap.
== Overview ==
There is no limit to how many times the player can restart the game, but there will be no further changes after the third iteration (NG+++, or NG+3).
== Changes ==
=== Max [[level]] ===
Each time a new iteration is started, the max level cap is increased by 5, until NG+3. After the third restart, the level cap stays the same. This means the maximum possible level that can be attained is 40 (25 from the base game, with an additional 5 from each NG+ iteration up to NG+3).
{| class="wikitable mw-collapsible mw-collapsed" style="text-align: right;"
! scope="col" | New Game
! scope="col" | Max level
|-
| 0 || 25
|-
| 1 || 30
|-
| 2 || 35
|-
| 3 || 40
|}
=== The Handler ===
In NG+, [[The Handler]] has an additional location near the first [[Homunculus]] in the [[Monastery#Lower|lower Monastery]].
[[Category:Game mechanics]]
d3138f3f7fa8eea7813d91a9269fb44c902991af
Category:Game mechanics
14
620
978
2025-08-21T21:36:21Z
Sharparam
284703
Created page with "Pages that describe concepts that make up how the game works."
wikitext
text/x-wiki
Pages that describe concepts that make up how the game works.
39eae09a03f9fcae63682fe46d2e3ddfb9af495f
NG+
0
621
979
2025-08-21T21:37:00Z
Sharparam
284703
Redirected page to [[New Game Plus]]
wikitext
text/x-wiki
#REDIRECT [[New Game Plus]]
8809153b9bcd913847df520edf01980e98855f5b
New Game+
0
622
980
2025-08-21T21:37:15Z
Sharparam
284703
Redirected page to [[New Game Plus]]
wikitext
text/x-wiki
#REDIRECT [[New Game Plus]]
8809153b9bcd913847df520edf01980e98855f5b
File:The Handler Blok 6147.png
6
623
981
2025-08-21T21:38:38Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:The Handler Deluge.png
6
624
982
2025-08-21T21:39:01Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:The Handler Asylum.png
6
625
983
2025-08-21T21:39:21Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:The Handler Upper Blocks.png
6
626
984
2025-08-21T21:39:40Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:The Handler Machinarium.png
6
627
985
2025-08-21T21:39:54Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:Homunculus Mirage.png
6
628
986
2025-08-21T21:47:54Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Homunculus
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Homunculus
}}
== Licensing ==
{{License|game}}
fc5c2ddb9ea822503dfa3596a0a0b4ff213f9f3d
File:Homunculus Mirage Husk.png
6
629
987
2025-08-21T21:48:41Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Homunculus1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Homunculus1
}}
== Licensing ==
{{License|game}}
fdcc48c10fce6b059573bc3c191c38246a9d4540
File:Ability Splinter.png
6
630
988
2025-08-21T22:07:29Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_99
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_99
}}
== Licensing ==
{{License|game}}
cc3d774105f02e18a0268d993eff4a288bbde91a
File:Upgrade Splinter.png
6
631
989
2025-08-21T22:12:53Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_64
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_64
}}
== Licensing ==
{{License|game}}
f7a6b20cf9ed043950eee055a324323c91f45780
File:Upgrade Module.png
6
632
990
2025-08-21T22:13:33Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRunes/ClassicRunes_66
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRunes/ClassicRunes_66
}}
== Licensing ==
{{License|game}}
06698d20f8bdb3e2489af2ec0362c661b1e82459
File:Handler Echo.png
6
633
991
2025-08-21T22:34:45Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/key__3_1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/key__3_1
}}
== Licensing ==
{{License|game}}
8faf7726b0945dd94b058d357fc1f997c9c568d9
File:Old Key.png
6
634
992
2025-08-21T22:35:49Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/Icon_OldKey
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/Icon_OldKey
}}
== Licensing ==
{{License|game}}
8dbd7a91e88980a16aa92acffed1f18d078d42db
File:Twinblade.png
6
635
993
2025-08-21T22:38:09Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Twinblade
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Twinblade
}}
== Licensing ==
{{License|game}}
f57b3438161ddfe6622c37effca2b63099b4ac31
File:Blades of Atropos.png
6
636
994
2025-08-21T22:39:05Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Atropos
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Atropos
}}
== Licensing ==
{{License|game}}
d6861ba34bbb0c868dacbf1a87e03d9d7c07f176
File:Daggers.png
6
637
995
2025-08-21T22:39:45Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Daggers1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Daggers1
}}
== Licensing ==
{{License|game}}
e7218b6cb1ed21937cd637c65a60bb67bccdca55
File:Kamas.png
6
638
996
2025-08-21T22:40:25Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Kama
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Kama
}}
== Licensing ==
{{License|game}}
5b145fc525755a6a2f4bbfd78888039f5348c836
File:Khopeshs.png
6
639
997
2025-08-21T22:41:05Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Khopesh
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Khopesh
}}
== Licensing ==
{{License|game}}
510571eda0c8cb67da332a8d77a80876aee87923
File:Lacerators.png
6
640
998
2025-08-21T22:41:40Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Lacerator
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Lacerator
}}
== Licensing ==
{{License|game}}
5362b7aa8a461a6f084269e5182de957f385a43f
File:Divine Greataxe.png
6
641
999
2025-08-21T22:42:16Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_DivineGreataxe
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_DivineGreataxe
}}
== Licensing ==
{{License|game}}
00f73c265cad1832e38da340f48f82cc61c4ec8a
File:Paladin Mace.png
6
642
1000
2025-08-21T22:43:14Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_PaladinHammer
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_PaladinHammer
}}
== Licensing ==
{{License|game}}
fd301ddc685577d335bd1a27f591cbcadbd7ca5b
File:Scimitar.png
6
643
1001
2025-08-21T22:43:48Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Scimitar
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Scimitar
}}
3aad4afb94525075ea36eb0555e0637f33d1228d
1002
1001
2025-08-21T22:44:14Z
Sharparam
284703
Add license
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Scimitar
}}
== Licensing ==
{{License|game}}
bef934861065d3f24dcb6fdae6d78ffdc5ecff1f
File:Anastasia.png
6
644
1003
2025-08-21T22:44:57Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Anastasia
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Anastasia
}}
== Licensing ==
{{License|game}}
132c2e9a61717db76ba25f12bb83d2614fbe4c15
File:Nodachi.png
6
645
1004
2025-08-21T22:45:35Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Nodachi
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Nodachi
}}
== Licensing ==
{{License|game}}
1905a4e62612e5745b6ed0facd953984c0559869
File:Royal Claymore.png
6
646
1005
2025-08-21T22:46:14Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_RoyalClaymore
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_RoyalClaymore
}}
== Licensing ==
{{License|game}}
039ef7deb84016626039991c1b0c99d2a268ef41
Royal Claymore
0
503
1006
771
2025-08-21T22:46:48Z
Sharparam
284703
Add note about normal [[Claymore]]
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Royal Claymore.png
| Type = Two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Claymore Swing, Sword Strike
| Mk3_Damage_min = 315
| Mk3_Damage_max = 344
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Location ==
{{coords|-9938|7939|-1340}}
Found in [[Desert|the Desert]]. Starting where the [[Shifting Sands]] data log can be found, climb up the stairs on either side and walk through the arch. The item can be seen across a gap. Do a jump while sprinting to cross the gap and reach the item.
== See also ==
* [[Claymore]] – The normal version of the weapon.
{{Navbox/Weapons}}
811d68f1793d05b574f32314fb8c2e0fd7382058
File:Soul Reaper.png
6
647
1007
2025-08-21T22:47:25Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Soulreaper
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Soulreaper
}}
== Licensing ==
{{License|game}}
2aaba316c56f0b5b2cdbf0449fd1c2c26a85906a
File:Valtiel.png
6
648
1008
2025-08-21T22:47:56Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Valtiel
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Valtiel
}}
== Licensing ==
{{License|game}}
107c0ec41d9dbd5a274cb131e01ae7d9cf000c40
File:Arcane Bow.png
6
649
1009
2025-08-21T22:48:31Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_ArcaneBow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_ArcaneBow
}}
== Licensing ==
{{License|game}}
9db94b2b997e955748afee80df0be40529fc81a5
File:Taskmaster.png
6
650
1010
2025-08-21T22:49:05Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Taskmaster
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Taskmaster
}}
== Licensing ==
{{License|game}}
b3bc57a59bcfa9e63f5e6e5695f456d2491bec54
File:Asklepios.png
6
651
1011
2025-08-21T22:49:39Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Asklepios
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Asklepios
}}
== Licensing ==
{{License|game}}
301ba27e8025b499157739bb8d92fa4aaa4381fb
File:Blessed Crosier.png
6
652
1012
2025-08-21T22:50:19Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Crosier
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Crosier
}}
== Licensing ==
{{License|game}}
105800c0a6a3bbaa9b74f85cce69844db316613e
File:Vermillion Staff.png
6
653
1013
2025-08-21T22:50:49Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_VermillionStaff
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_VermillionStaff
}}
== Licensing ==
{{License|game}}
ed8025b89564e7e52c655ea6ef1b33da408b557b
Twinblades
0
654
1014
2025-08-21T22:51:18Z
Sharparam
284703
Created page with "'''Twinblades''' are a type of [[Weapons|weapon]] in {{BFF}}. [[Category:Twinblades]]"
wikitext
text/x-wiki
'''Twinblades''' are a type of [[Weapons|weapon]] in {{BFF}}.
[[Category:Twinblades]]
6cf4c13012b9674afbf0c196a84986b92f6c394c
Category:Twinblades
14
655
1015
2025-08-21T22:51:46Z
Sharparam
284703
Created page with "[[Category:Two-handed weapons]]"
wikitext
text/x-wiki
[[Category:Two-handed weapons]]
797f628182636dd7d53e09a5330ca3c8e98ffe59
Greatweapons
0
656
1016
2025-08-21T22:52:20Z
Sharparam
284703
Created page with "'''Greatweapons''' are a type of [[Two-handed weapons|two-handed weapon]] in {{BFF}}. [[Category:Greatweapons]]"
wikitext
text/x-wiki
'''Greatweapons''' are a type of [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
[[Category:Greatweapons]]
e6ca350d0fb12afe7023946321db37dda9360e39
Category:Greatweapons
14
657
1017
2025-08-21T22:52:32Z
Sharparam
284703
Created page with "[[Category:Two-handed weapons]]"
wikitext
text/x-wiki
[[Category:Two-handed weapons]]
797f628182636dd7d53e09a5330ca3c8e98ffe59
Two-handed weapons
0
658
1018
2025-08-21T22:53:14Z
Sharparam
284703
Created page with "'''Two-handed weapons''' are a type of [[Weapons|weapon]] in {{BFF}}. As they require wielding with both hands, a [[Shields|shield]] cannot be equipped at the same time. [[Category:Two-handed weapons]]"
wikitext
text/x-wiki
'''Two-handed weapons''' are a type of [[Weapons|weapon]] in {{BFF}}. As they require wielding with both hands, a [[Shields|shield]] cannot be equipped at the same time.
[[Category:Two-handed weapons]]
ac75a2ff82d7dc4dcc2faff8bb98a7e16898edc2
Ranged weapons
0
659
1019
2025-08-21T22:54:19Z
Sharparam
284703
Created page with "'''Ranged weapons''' in {{BFF}} can be used to attack enemies at range, without having to get into melee distance. == Overview == There are two types of ranged weapons, [[longbows]] and [[staves]]. [[Category:Ranged weapons]]"
wikitext
text/x-wiki
'''Ranged weapons''' in {{BFF}} can be used to attack enemies at range, without having to get into melee distance.
== Overview ==
There are two types of ranged weapons, [[longbows]] and [[staves]].
[[Category:Ranged weapons]]
8959093ae31819cb3ccc6a125991241501951913
Longbows
0
660
1020
2025-08-21T22:54:52Z
Sharparam
284703
Created page with "'''Longbows''' are a type of [[Ranged weapons|ranged weapon]] in {{BFF}}. They are currently the only type of bow available. [[Category:Longbows]]"
wikitext
text/x-wiki
'''Longbows''' are a type of [[Ranged weapons|ranged weapon]] in {{BFF}}. They are currently the only type of bow available.
[[Category:Longbows]]
c497b3be60be0f4b1eca6d7ad8060afc43fe2f21
Staves
0
661
1021
2025-08-21T22:55:21Z
Sharparam
284703
Created page with "'''Staves''' are a type of [[Ranged weapons|ranged weapon]] in {{BFF}}. [[Category:Staves]]"
wikitext
text/x-wiki
'''Staves''' are a type of [[Ranged weapons|ranged weapon]] in {{BFF}}.
[[Category:Staves]]
8f6d470b45b1575b318b02cf1c263572c30e4e8b
Upgrade items
0
662
1022
2025-08-21T22:57:48Z
Sharparam
284703
Created page with "'''Upgrade items''' in {{BFF}} can be used to upgrade equipment to higher mark levels. == Overview == There are two upgrade items available. === Upgrade Splinter === {{Main|Upgrade Splinter}} Upgrade splinters are used to upgrade [[equipment]] to Mk 1, 2, and 3. === Upgrade Modules === {{Main|Upgrade Module}} Upgrade modules are used to upgrade equipment to Mk 4 and 5. [[Category:Upgrade items]]"
wikitext
text/x-wiki
'''Upgrade items''' in {{BFF}} can be used to upgrade equipment to higher mark levels.
== Overview ==
There are two upgrade items available.
=== Upgrade Splinter ===
{{Main|Upgrade Splinter}}
Upgrade splinters are used to upgrade [[equipment]] to Mk 1, 2, and 3.
=== Upgrade Modules ===
{{Main|Upgrade Module}}
Upgrade modules are used to upgrade equipment to Mk 4 and 5.
[[Category:Upgrade items]]
cb0f9a551001e3b722320d79fdf946e6eddcf8b6
Template:Navbox/Essential items
10
663
1023
2025-08-21T23:01:04Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Essential items | title = [[Essential items]] | list1 = * [[Ability Splinter]] * [[Handler Echo]] * [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]]) * [[Mobius Blade]] * [[Old Key]] * [[Perk Essence]] ([[Unstable Perk Essence|Unstable]]) * [[Plagued Blood]] * [[Scanner]] | group1.1 = [[Upgrade items|Upgrade]] | list1.1 = * [[Upgrade Splinter]] * [[Upgrade Module]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Essential items
| title = [[Essential items]]
| list1 =
* [[Ability Splinter]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group1.1 = [[Upgrade items|Upgrade]]
| list1.1 =
* [[Upgrade Splinter]]
* [[Upgrade Module]]
}}<noinclude>{{Documentation}}</noinclude>
1adce5372339cfa58118bd7b6ed5a8d7f993200d
Template:Navbox/Essential items/doc
10
664
1024
2025-08-21T23:01:37Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
a072d936de3f697ea20b212186fc4bf85674e635
Template:Navbox/Items
10
285
1025
323
2025-08-21T23:02:22Z
Sharparam
284703
Move essential items to child navbox
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Essential items|Essential]]
| list1 = {{Navbox/Essential items|child}}
| group2 = [[Anomalous crystals]]
| list2 = {{Navbox/Anomalous crystals|child}}
| group3 = [[Consumables]]
| list3 = {{Navbox/Consumables|child}}
| group4 = [[Equipment]]
| list4 = {{Navbox/Equipment|child}}
| group5 = [[Materials]]
| list5 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
69d95ac18f0d9bf0023d12092ad0a5f2ddc9990b
Essential items
0
665
1026
2025-08-21T23:02:43Z
Sharparam
284703
Created page with "{{Navbox/Essential items}} [[Category:Essential items]]"
wikitext
text/x-wiki
{{Navbox/Essential items}}
[[Category:Essential items]]
02ca5641a551e0ead287a697a66ea738ef164267
Mobius Blade
0
666
1027
2025-08-21T23:07:40Z
Sharparam
284703
Created page with "{{Infobox/Item | type = essential | image = Mobius Blade.png }} '''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}. == Overview == The player can use the blade to kill themselves, allowing them to respawn at the [[homunculus]] they last saved their position at (or a [[Homunculus Mirage]]). {{Navbox/Essential items}}"
wikitext
text/x-wiki
{{Infobox/Item
| type = essential
| image = Mobius Blade.png
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Overview ==
The player can use the blade to kill themselves, allowing them to respawn at the [[homunculus]] they last saved their position at (or a [[Homunculus Mirage]]).
{{Navbox/Essential items}}
4865fb010f21a17b4d993d6f39357d69eadea7b7
File:Mobius Blade.png
6
667
1028
2025-08-21T23:08:26Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_MobiusBlade
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_MobiusBlade
}}
== Licensing ==
{{License|game}}
9ef3d7d55709957c049a3375b5b88ae6202d3eb4
File:Folk Cape.png
6
668
1029
2025-08-21T23:40:37Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_FolkCape
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_FolkCape
}}
== Licensing ==
{{License|game}}
1e1acda1f5c3e858a7735b33901fc7a37c770bfa
File:Corrupted Cape.png
6
669
1030
2025-08-21T23:41:21Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CorruptedCape
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CorruptedCape
}}
== Licensing ==
{{License|game}}
86ede209dfdff68e916fa5aafb18b559581d91f8
File:Techpriest Cape.png
6
670
1031
2025-08-21T23:44:18Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_HighPriestCape
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_HighPriestCape
}}
== Licensing ==
{{License|game}}
32d01bfc81b007ced7bde3a6456418a748fb4857
Techpriest Cape
0
515
1032
794
2025-08-21T23:44:51Z
Sharparam
284703
Add note on internal game file name
wikitext
text/x-wiki
{{Infobox/Cape
| image = Techpriest Cape
| title = {{PAGENAME}}
| Effect1 = +50 Max [[flux]] points.
| Effect2 = +150 [[Flux]] leech rating.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}} that can be worn by the player.
== Location ==
{{coords|-4527|8973|9614}}
Found in [[Asylum]]. After entering the first courtyard, climb the stairs on the right and jump onto the right ledge, then follow it backwards (towards the direction you entered from) and the item will be on a corpse on the left.
== Trivia ==
* "Techpriest" in the name might be a reference to [https://wh40k.lexicanum.com/wiki/Tech-priest tech-priests] from [[w:Warhammer 40,000|Warhammer 40,000]].
* The cape is called "HighPriestCape" in the game files.
{{Navbox/Capes}}
564e35049b1bb09829bde7aab564b7e15b98d8db
1033
1032
2025-08-21T23:45:34Z
Sharparam
284703
Fix image name
wikitext
text/x-wiki
{{Infobox/Cape
| image = Techpriest Cape.png
| title = {{PAGENAME}}
| Effect1 = +50 Max [[flux]] points.
| Effect2 = +150 [[Flux]] leech rating.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}} that can be worn by the player.
== Location ==
{{coords|-4527|8973|9614}}
Found in [[Asylum]]. After entering the first courtyard, climb the stairs on the right and jump onto the right ledge, then follow it backwards (towards the direction you entered from) and the item will be on a corpse on the left.
== Trivia ==
* "Techpriest" in the name might be a reference to [https://wh40k.lexicanum.com/wiki/Tech-priest tech-priests] from [[w:Warhammer 40,000|Warhammer 40,000]].
* The cape is called "HighPriestCape" in the game files.
{{Navbox/Capes}}
3222744a93dd1658eafe1d855b99f59e8a1de857
File:Wanderer Cape.png
6
671
1034
2025-08-21T23:46:08Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_WandererCape
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_WandererCape
}}
== Licensing ==
{{License|game}}
59f5d1d11c35ee9a04826ad1f5ff33f51646d7ac
File:Librarian Hood.png
6
672
1035
2025-08-21T23:48:51Z
Sharparam
284703
{{Game file
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibraryHood
}}
wikitext
text/x-wiki
== Summary ==
{{Game file
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibraryHood
}}
== Licensing ==
{{License|game}}
110860aa292ef66d5f6ed3b6afa7920caee63ee0
1061
1035
2025-08-22T00:23:39Z
Sharparam
284703
Fix template name
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibraryHood
}}
== Licensing ==
{{License|game}}
bea980a0ea5124ea67512b1dbc156457b8428213
File:Plagued Revenant Helmet.png
6
673
1036
2025-08-21T23:49:28Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_PlaguedRevenantHelmet
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_PlaguedRevenantHelmet
}}
== Licensing ==
{{License|game}}
adcd5cca12e8cb8758dc92663575b61298d942ac
File:Skullface Helmet.png
6
674
1037
2025-08-21T23:50:01Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_Skullface
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_Skullface
}}
== Licensing ==
{{License|game}}
13eb7e5ec1d14cf7ea75b4d27004fea01cd10745
File:Techpriest Helmet.png
6
675
1038
2025-08-21T23:50:38Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_Techpriest
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_Techpriest
}}
== Licensing ==
{{License|game}}
249ed277fd956d36cddc43935f1f56f08cca9eef
File:Citadel Warrior Chest.png
6
676
1039
2025-08-21T23:51:13Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_WarriorCuirass
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_WarriorCuirass
}}
== Licensing ==
{{License|game}}
1e4cb45419070142433921a992c177f948e7f846
File:Corrupted Cuirass.png
6
677
1040
2025-08-21T23:51:40Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CorruptChest
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CorruptChest
}}
== Licensing ==
{{License|game}}
6af71d11c2d4579dfa923f8f77aaf4a4c087597c
File:Librarian Overcoat.png
6
678
1041
2025-08-21T23:52:14Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibrarianChest
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibrarianChest
}}
== Licensing ==
{{License|game}}
c77e94b8315764c85113e24c9674a1c6c8cf8fda
File:Librarian Trousers.png
6
679
1042
2025-08-21T23:52:46Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibraryPants
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_LibraryPants
}}
== Licensing ==
{{License|game}}
7177dd164cc4369689e183b83b300d4e95a07b0f
File:Upper Blocks.png
6
680
1043
2025-08-22T00:00:33Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/UpperBlocks
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/UpperBlocks
}}
== Licensing ==
{{License|game}}
7cfe449c7d77f4edb4b76116219f67466bf01fa8
File:Rain District (Sewers).png
6
681
1044
2025-08-22T00:01:11Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/RainDistrict_Sewer
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/RainDistrict_Sewer
}}
== Licensing ==
{{License|game}}
9e5470e55d56bba0e4dad6b63c457a1c08dd0bcb
File:Rain District (Center).png
6
682
1045
2025-08-22T00:01:37Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/RainDistrict_Center
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/RainDistrict_Center
}}
== Licensing ==
{{License|game}}
70759fe0eec60d5d0ce99da02d4eaac2cb63203b
File:Deluge.png
6
683
1046
2025-08-22T00:02:00Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Deluge
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Deluge
}}
== Licensing ==
{{License|game}}
cfc96f2e156ae120c5e6bf630617f999bee3d4f9
File:Asylum.png
6
684
1047
2025-08-22T00:02:23Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Asylum
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Asylum
}}
== Licensing ==
{{License|game}}
50c6dcfd17601590137c501e8d93f4b61fbd2f45
File:Ghost Town (Floor 13).png
6
685
1048
2025-08-22T00:02:55Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/GhostTown
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/GhostTown
}}
== Licensing ==
{{License|game}}
0974507d010f1d5de5e3b6affaeb63d6fd4b9fcd
File:Ghost Town (Floor 1).png
6
686
1049
2025-08-22T00:03:13Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/GhostTown_Floor1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/GhostTown_Floor1
}}
== Licensing ==
{{License|game}}
9648988f1c9544e7583148058fc05b32671ea75f
File:Machinarium.png
6
687
1050
2025-08-22T00:03:38Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Machinarium
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Machinarium
}}
== Licensing ==
{{License|game}}
95d75682881ecf1489569c7a882291ae51becc5c
File:Desert.png
6
688
1051
2025-08-22T00:03:59Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Desert
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Desert
}}
== Licensing ==
{{License|game}}
233e96a1fc045c10cc5d2580564d904c2a477c26
File:Desert Mirage.png
6
689
1052
2025-08-22T00:04:26Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/DesertMirage
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/DesertMirage
}}
== Licensing ==
{{License|game}}
7d227ef4860febfdb792b9c1cc849a3d35a7bb6f
File:Anomaly.png
6
690
1053
2025-08-22T00:04:49Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Anomaly
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/Anomaly
}}
== Licensing ==
{{License|game}}
26aca621fbecbbfc5a2a8e46e0bb2f3ad61c640e
File:Vermillion Fields (Plaza).png
6
691
1054
2025-08-22T00:05:30Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/VermillionPlaza
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/VermillionPlaza
}}
== Licensing ==
{{License|game}}
47f31e8ce34e4bf716aae7924e3d8dbb2fcebdff
File:Vermillion Fields (Temple).png
6
692
1055
2025-08-22T00:05:52Z
Sharparam
284703
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/VermillionTemple
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Blueprints/HUD/FastTravel/LocationScreens/VermillionTemple
}}
== Licensing ==
{{License|game}}
2b5902316fc2a4752f3e3d19b8eba897da81610f
File:Statues location.jpg
6
693
1056
2025-08-22T00:08:12Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:Crescent Axe.png
6
694
1057
2025-08-22T00:11:06Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_CrescentAxe
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_CrescentAxe
}}
== Licensing ==
{{License|game}}
e4f60d5d622c5eb43841b4ffc6b32d78ce3cd014
Crescent Axe
0
502
1058
769
2025-08-22T00:11:35Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Crescent Axe.png
| Type = two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Expose Armor, Crescent Slash
| Mk2_Damage_min = 251
| Mk2_Damage_max = 271
}}
== Location ==
{{coords|-3932|1535|1532}}
Located in the room with [[The Banshee]] [[Data logs|data log]].
{{Navbox/Weapons}}
a8301762c20f8a07104c5e919cb9fbfceed2e8f5
1060
1058
2025-08-22T00:20:03Z
Sharparam
284703
Add description
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Crescent Axe.png
| Type = two-handed
| Damage type = Sharp
| Speed = Slow
| Abilities = Expose Armor, Crescent Slash
| Mk2_Damage_min = 251
| Mk2_Damage_max = 271
}}
'''{{PAGENAME}}''' is a [[Two-handed weapons|two-handed weapon]] in {{BFF}}.
== Location ==
{{coords|-3932|1535|1532}}
Located in the room with [[The Banshee]] [[Data logs|data log]].
{{Navbox/Weapons}}
00b81a1c9f4c6b9f1f6a2a0308f9d8036122d562
Template:Navbox/Weapons
10
438
1059
645
2025-08-22T00:12:35Z
Sharparam
284703
Add [[Crescent Axe]]
wikitext
text/x-wiki
<!-- Weapons must be listed in alphabetical order! -->
{{Navbox
| {{{1|}}}
| template = Navbox/Weapons
| title = [[Weapons]]
| group1 = [[One-handed weapons|One-handed]]
| list1 =
* [[Arming Sword]]
* [[Industrial Axe]]
* [[Industrial Mace]]
* [[Iron Pipe]]
* [[Longsword]]
* [[Machinist's Hammer]]
* [[Morning Star]]
* [[Paladin Mace]]
* [[Ratagan Sabre]]
* [[Scimitar]]
* [[Soul Breaker]]
* [[Tire Iron]]
* [[Torch]]
* [[Woodchopper]]
| group2 = [[Two-handed weapons|Two-handed]]
| list2 =
* [[Anastasia]]
* [[Claymore]]
* [[Crescent Axe]]
* [[Faussart]]
* [[Halberd]]
* [[Mechanical Tenderizer]]
* [[Nodachi]]
* [[Royal Claymore]]
* [[Rusty Claymore]]
* [[Solaris]]
* [[Soul Reaper]]
* [[Valtiel]]
| group2.1 = [[Dual Wields]]
| list2.1 =
* [[Blades of Atropos]]
* [[Daggers]]
* [[Kamas]]
* [[Katanas]]
* [[Khopeshs]]
* [[Lacerators]]
| group2.2 = [[Twinblades]]
| list2.2 =
* [[Twinblade]]
| group2.3 = [[Greatweapons]]
| list2.3 =
* [[Armor Buster]]
* [[Divine Greataxe]]
* [[Eviscerator]]
* [[Greathammer]]
| group3 = [[Ranged weapons|Ranged]]
| group3.1 = [[Longbows]]
| list3.1 =
* [[Arcane Bow]]
* [[Longbow]]
* [[Taskmaster]]
* [[Winged bow]]
| group3.2 = [[Staves]]
| list3.2 =
* [[Asklepios]]
* [[Blessed Crosier]]
* [[Evolved Staff]]
* [[Mechanomad Staff]]
* [[Vermillion Staff]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
58088fcaffd9bc941436dc381724677f054ceb46
Category:Helmets
14
695
1062
2025-08-22T00:25:01Z
Sharparam
284703
Created page with "[[Category:Armor]]"
wikitext
text/x-wiki
[[Category:Armor]]
8dbf198b5dcaa87a18100850cc78880444b773ad
Heartbeat
0
388
1063
539
2025-08-22T00:25:42Z
Sharparam
284703
Fix category
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] in {{BFF}}.
== Overview ==
{{Quote
|Have you ever tried to paint a loved one's face from memory? The image shifts and deforms, highlighting the mind's fleeting nature. Drawing from memory is an abstract skill, breathing and heartbeats are automatic. Now, even these feel abstract to me. I have to consciously breathe and encourage my heart to beat, doubting its rhythm if I can't feel it. My heartbeat feels like as word repeated until it loses meaning. Nothing endures here.
}}
== Location ==
{{coords|3326|-6471|-6573}}
Found in the [[Monastery#Lower|Monastery (Lower)]]. Starting at the [[Homunculus]], go forward until the end of the roof where the first enemy is, then take the left path that goes down several stairs. Continue into the hallway at the bottom and take a left, then go up the elevator. Go straight and you'll come to a platform with a staircase going up to the right. The data log is right before the staircase. Use [[Scanner|the scanner]] to more easily find it.
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
6b4655eec7f3f3e087d002c3a1281d247e0b0cf2
Category:Legguards
14
696
1064
2025-08-22T00:26:02Z
Sharparam
284703
Created page with "[[Category:Armor]]"
wikitext
text/x-wiki
[[Category:Armor]]
8dbf198b5dcaa87a18100850cc78880444b773ad
Category:Materials
14
697
1065
2025-08-22T00:26:18Z
Sharparam
284703
Created page with "[[Category:Items]]"
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Category:Modules
14
698
1066
2025-08-22T00:26:37Z
Sharparam
284703
Created page with "Lua modules."
wikitext
text/x-wiki
Lua modules.
079e82b53167721297f91da34adfc9459140e554
Category:Pages that need coordinates
14
699
1067
2025-08-22T00:27:59Z
Sharparam
284703
Created page with "Pages that are missing coordinates to help players locate them. Either add coordinates to a "Location" or "Acquisition" section, or to an infobox, as appropriate. Coordinates can be specified by using the {{tl|Coordinates}} template."
wikitext
text/x-wiki
Pages that are missing coordinates to help players locate them.
Either add coordinates to a "Location" or "Acquisition" section, or to an infobox, as appropriate.
Coordinates can be specified by using the {{tl|Coordinates}} template.
c583e0f1126353a4444174e9d73b247ae2968254
Skullface Helmet
0
490
1068
745
2025-08-22T00:30:40Z
Sharparam
284703
Fix formatting of passives
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Skullface Helmet.png
| Type = Helmet
| Weight = Light
| Passives = Volatile Illusions
| Mk5_Sharp = 692
| Mk5_Blunt = 692
| Mk5_Technomancy = 928
}}
== Location ==
{{coords|-4063|1564|1686}}
After reaching the room with a big circular elevator in the middle, look around the edges of the room for a bookshelf containing the helmet.
{{Navbox/Armor}}
d5a1b5a552329e4ac95e57677ce97662ce7115e3
Template:Infobox/Armor
10
453
1069
671
2025-08-22T00:31:55Z
Sharparam
284703
Use {{tl:Plainlist}} instead of {{tl:Hlist}} for passives
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Weight,Set,Passives
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| helmet = [[Helmet]]
| pauldrons = [[Pauldrons]]
| chestguard = [[Chestguard]]
| legguard = [[Legguard]]
| gauntlet = [[Gauntlet]]
| #default = {{{Type}}}
}}}}
|Set={{#if:{{{Set|}}}|[[{{{Set}}}]]}}
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \!
| token = @@@@
| pattern = [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| helmet = [[Category:Helmets]]
| pauldrons = [[Category:Pauldrons]]
| chestguard = [[Category:Chestguards]]
| legguard = [[Category:Legguards]]
| gauntlet = [[Category:Gauntlets]]
| #default = [[Category:Armor]]
}}{{Armor/CargoStore
|name={{{title|}}}
|setname={{{Set|}}}
|type={{{Type|}}}
|weight={{{Weight|}}}
|sharpMk0={{{Mk0_Sharp|}}}
|bluntMk0={{{Mk0_Blunt|}}}
|technomancyMk0={{{Mk0_Technomancy|}}}
|sharpMk1={{{Mk1_Sharp|}}}
|bluntMk1={{{Mk1_Blunt|}}}
|technomancyMk1={{{Mk1_Technomancy|}}}
|sharpMk2={{{Mk2_Sharp|}}}
|bluntMk2={{{Mk2_Blunt|}}}
|technomancyMk2={{{Mk2_Technomancy|}}}
|sharpMk3={{{Mk3_Sharp|}}}
|bluntMk3={{{Mk3_Blunt|}}}
|technomancyMk3={{{Mk3_Technomancy|}}}
|sharpMk4={{{Mk4_Sharp|}}}
|bluntMk4={{{Mk4_Blunt|}}}
|technomancyMk4={{{Mk4_Technomancy|}}}
|sharpMk5={{{Mk5_Sharp|}}}
|bluntMk5={{{Mk5_Blunt|}}}
|technomancyMk5={{{Mk5_Technomancy|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
87c41b6009da8db75d705c5a2cd72f5ef3ad20d0
Techpriest Helmet
0
491
1070
747
2025-08-22T00:32:35Z
Sharparam
284703
Fix passives list
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Techpriest Helmet.png
| Type = Helmet
| Weight = Light
| Passives = Minor Flux Regen
| Mk5_Sharp = 722
| Mk5_Blunt = 722
| Mk5_Technomancy = 928
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|1272|-8495|551}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], head through the doorway and take the left path. After reaching the outdoors area, head up the stairs and take a narrow path on the right leading to a small area behind a building with the helmet in a corner.
{{Navbox/Armor}}
6bf0cbd27f554dbd5cd936fb46578e34b4b84ae6
Module:Track listing/styles.css
828
414
1071
589
2025-08-22T00:33:18Z
Sharparam
284703
Remove unused template
sanitized-css
text/css
.tracklist {
border-spacing: 0;
}
/* set on all rows we can set the total length row to transparent */
.tracklist tr {
background-color: var(--background-color-base, #fff);
}
.tracklist tr:nth-child(2n-1) {
background-color: var(--background-color-neutral-subtle, #f8f9fa);
}
.tracklist caption {
text-align: left;
font-weight: bold;
}
.tracklist td,
.tracklist th[scope="row"] {
vertical-align: top;
}
.tracklist th[scope="col"] {
text-align: left;
background-color: var(--background-color-neutral, #eaecf0);
}
.tracklist th.tracklist-length-header,
.tracklist th.tracklist-number-header,
.tracklist th[scope="row"],
.tracklist-length,
.tracklist-total-length td {
padding-right: 10px;
text-align: right;
}
.tracklist th[scope="row"] {
font-weight: normal;
}
.tracklist-number-header {
width: 2em;
padding-left: 10px;
}
.tracklist-length-header {
width: 4em;
}
.tracklist tr.tracklist-total-length {
background-color: transparent;
}
.tracklist .tracklist-total-length th {
padding: 0;
font-weight: bold;
}
.tracklist-total-length th > span {
float: right;
padding: 0 10px;
background-color: var(--background-color-neutral, #eaecf0);
}
.tracklist-total-length td {
background-color: var(--background-color-neutral, #eaecf0);
font-weight: bold;
padding: 0 10px 0 0;
}
f8262e857e4655dfadbdb5ad31f192ca96a267be
Module:Hatnote/styles.css
828
415
1072
590
2025-08-22T00:33:37Z
Sharparam
284703
Remove unused template
sanitized-css
text/css
.hatnote {
font-style: italic;
}
/* Limit structure CSS to divs because of [[Module:Hatnote inline]] */
div.hatnote {
/* @noflip */
padding-left: 1.6em;
margin-bottom: 0.5em;
}
.hatnote i {
font-style: normal;
}
/* The templatestyles element inserts a link element before hatnotes.
* TODO: Remove link if/when WMF resolves T200206 */
.hatnote + link + .hatnote {
margin-top: -0.5em;
}
@media print {
body.ns-0 .hatnote {
display: none !important;
}
}
eacdbf0b74568c1efba92340368f477c45b286e6
Template:Order of magnitude
10
700
1073
2025-08-22T00:35:53Z
Sharparam
284703
Created page with "<includeonly>{{safesubst:<noinclude/>#ifexpr:{{{1|0}}}=0 |{{safesubst:<noinclude/>#ifexpr:abs{{{1|0}}}1=1 |0 |{{safesubst:<noinclude/>#expr:floor((ln(abs{{{1}}}1)/ln10)+1)}} }} |{{safesubst:<noinclude/>#expr:floor((ln(abs({{{1|0}}}) )/ln 10)+1E((abs{{{1|0}}}>1E100 or abs{{{1|0}}}<1E-100)-14))}} }}</includeonly><noinclude> {{documentation}} </noinclude>"
wikitext
text/x-wiki
<includeonly>{{safesubst:<noinclude/>#ifexpr:{{{1|0}}}=0
|{{safesubst:<noinclude/>#ifexpr:abs{{{1|0}}}1=1
|0
|{{safesubst:<noinclude/>#expr:floor((ln(abs{{{1}}}1)/ln10)+1)}}
}}
|{{safesubst:<noinclude/>#expr:floor((ln(abs({{{1|0}}}) )/ln 10)+1E((abs{{{1|0}}}>1E100 or abs{{{1|0}}}<1E-100)-14))}}
}}</includeonly><noinclude>
{{documentation}}
</noinclude>
cede5694e8ebb404ecdd17ae1f8e1c5d19562728
Module:Sortkey
828
701
1074
2025-08-22T00:36:58Z
Sharparam
284703
Created page with "local getArgs = require('Module:Arguments').getArgs local p = {} function p._encode(sortkey) -- Protect against sortkey nesting. -- Example: {{sort|{{dts|2013|07|07}}|{{dts|1990|12|01}}}} if string.find(sortkey, "sortkey") or string.find(sortkey, "data-sort-value") then return ""; end return mw.text.encode(sortkey) end function p.encode(frame) local args = getArgs(frame); return p._encode(args[1] or "") end local function valid_number(num) -- Return true..."
Scribunto
text/plain
local getArgs = require('Module:Arguments').getArgs
local p = {}
function p._encode(sortkey)
-- Protect against sortkey nesting.
-- Example: {{sort|{{dts|2013|07|07}}|{{dts|1990|12|01}}}}
if string.find(sortkey, "sortkey") or string.find(sortkey, "data-sort-value") then
return "";
end
return mw.text.encode(sortkey)
end
function p.encode(frame)
local args = getArgs(frame);
return p._encode(args[1] or "")
end
local function valid_number(num)
-- Return true if num is a valid number.
-- In Scribunto (different from some standard Lua), when expressed as a string,
-- overflow or other problems are indicated with text like "inf" or "nan"
-- which are regarded as invalid here (each contains "n").
if type(num) == 'number' and tostring(num):find('n', 1, true) == nil then
return true
end
end
function p._sortKeyForNumber(value)
local sortkey
if not valid_number(value) then
if value < 0 then
sortkey = '1000000000000000000'
else
sortkey = '9000000000000000000'
end
elseif value == 0 then
sortkey = '5000000000000000000'
else
local mag = math.floor(math.log10(math.abs(value)) + 1e-14)
local prefix
if value > 0 then
prefix = 7000 + mag
else
prefix = 2999 - mag
value = value + 10^(mag+1)
end
sortkey = string.format('%d', prefix) .. string.format('%015.0f', math.floor(value * 10^(math.min(28,14-mag))))
end
return sortkey;
end
function p.sortKeyForNumber(frame)
local args = getArgs(frame);
return p._sortKeyForNumber(args[1] or "")
end
return p
61c7b121abc7df4d9f0cab5456de8cb0de4ed1e2
Template:Hidden sort key
10
702
1075
2025-08-22T00:37:33Z
Sharparam
284703
Created page with "<span data-sort-value="{{#invoke:sortkey|encode|{{{1}}}}}" style="display:none;"></span><noinclude> {{Documentation}} </noinclude>"
wikitext
text/x-wiki
<span data-sort-value="{{#invoke:sortkey|encode|{{{1}}}}}" style="display:none;"></span><noinclude>
{{Documentation}}
</noinclude>
90e59249d00fc722efaf114ab4f6d3c2edcf640c
Template:Hid
10
703
1076
2025-08-22T00:37:50Z
Sharparam
284703
Redirected page to [[Template:Hidden sort key]]
wikitext
text/x-wiki
#REDIRECT [[Template:Hidden sort key]]
3c894cab38ac0a316503172fe1f0de434c40bae8
Template:Round
10
704
1077
2025-08-22T00:37:59Z
Sharparam
284703
Created page with "<includeonly>{{safesubst<noinclude/>:#iferror:{{#expr:{{{2|0}}}}} | {{main other|[[Category:Pages with bad rounding precision]]}}{{hid|Bad rounding here}}<!-- -->{{safesubst<noinclude/>:#invoke:Math|precision_format| {{{1}}} | 1-{{order of magnitude|{{{1}}}}} }}| {{safesubst<noinclude/>:#invoke:Math|precision_format| {{{1}}} | {{{2|0}}}}}}}</includeonly><noinclude> {{documentation}} </noinclude>"
wikitext
text/x-wiki
<includeonly>{{safesubst<noinclude/>:#iferror:{{#expr:{{{2|0}}}}} |
{{main other|[[Category:Pages with bad rounding precision]]}}{{hid|Bad rounding here}}<!--
-->{{safesubst<noinclude/>:#invoke:Math|precision_format| {{{1}}} | 1-{{order of magnitude|{{{1}}}}} }}|
{{safesubst<noinclude/>:#invoke:Math|precision_format| {{{1}}} | {{{2|0}}}}}}}</includeonly><noinclude>
{{documentation}}
</noinclude>
9c2874586b74824fe1beb6830b56eabe7ad936ce
Template:Median
10
705
1078
2025-08-22T00:38:36Z
Sharparam
284703
Created page with "{{#invoke:math|median}} <noinclude>{{doc}}</noinclude>"
wikitext
text/x-wiki
{{#invoke:math|median}} <noinclude>{{doc}}</noinclude>
57105bd7f84192a6b93c460a09f4acb9700dfd24
Template:Median/doc
10
706
1079
2025-08-22T00:39:07Z
Sharparam
284703
Created page with "This template is used to find the median of a series of numbers. {{clear}} ==Parameters== Parameters with a number as the value are the numbers to find the average of. ==Examples== *<syntaxhighlight lang="wikitext" inline>{{Median|10|20|30|40|50|1000}}</syntaxhighlight> → {{Median|20|10|30|40|50|1000}} *<syntaxhighlight lang="wikitext" inline>{{Median|10|20|30|50|1000}}</syntaxhighlight> → {{Median|20|10|30|50|1000}} *<syntaxhighlight lang="wikitext" inline>{{Median|..."
wikitext
text/x-wiki
This template is used to find the median of a series of numbers.
{{clear}}
==Parameters==
Parameters with a number as the value are the numbers to find the average of.
==Examples==
*<syntaxhighlight lang="wikitext" inline>{{Median|10|20|30|40|50|1000}}</syntaxhighlight> → {{Median|20|10|30|40|50|1000}}
*<syntaxhighlight lang="wikitext" inline>{{Median|10|20|30|50|1000}}</syntaxhighlight> → {{Median|20|10|30|50|1000}}
*<syntaxhighlight lang="wikitext" inline>{{Median|10.1|20.1|30.1|50.1|1000.1}}</syntaxhighlight> → {{Median|20.1|10.1|30.1|50.1|1000.1}}
==See also==
*{{tl|Average}}
6f5fe5da1f5a16fe5f485990dc980ccd555dfac7
Level
0
707
1081
1080
2025-08-22T00:43:08Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{stub}}
'''{{PAGENAME}}''' is a measure of a player's experience.
== Overview ==
The level increases by gaining experience points through exploration, defeating [[enemies]], and picking up or interacting with [[items]] or [[lore]] objects.
The amount of experience points required to reach further levels will regularly increase, although not with every level.
Every level up also grants two attribute points that can be used to increase player [[attributes]]. When reaching level 25 you get 6 points instead of 2.
The max level is 25, with each [[NG+]] iteration increasing the cap by 5, to a maximum of 40 in [[NG+|NG+3]].
{| class="wikitable sticky-header hover-highlight" style="text-align: right;"
|-
! scope="col" | Level
! scope="col" | EXP to next
! scope="col" | Cost increase
! scope="col" | Total EXP
|-
| 0 || {{fnum|480}} || {{fnum|480}} || {{fnum|0}}
|-
| 1 || {{fnum|1220}} || {{fnum|740}} || {{fnum|480}}
|-
| 2 || {{fnum|2250}} || {{fnum|1030}} || {{fnum|1700}}
|-
| 3 || {{fnum|13500}} || {{fnum|11250}} || {{fnum|3950}}
|-
| 4 || {{fnum|13500}} || {{fnum|0}} || {{fnum|17450}}
|-
| 5 || {{fnum|15000}} || {{fnum|1500}} || {{fnum|30950}}
|-
| 6 || {{fnum|15000}} || {{fnum|0}} || {{fnum|45950}}
|-
| 7 || {{fnum|15000}} || {{fnum|0}} || {{fnum|60950}}
|-
| 8 || {{fnum|15000}} || {{fnum|0}} || {{fnum|75950}}
|-
| 9 || {{fnum|15000}} || {{fnum|0}} || {{fnum|90950}}
|-
| 10 || {{fnum|18500}} || {{fnum|3500}} || {{fnum|105950}}
|-
| 11 || {{fnum|18500}} || {{fnum|0}} || {{fnum|124450}}
|-
| 12 || {{fnum|18500}} || {{fnum|0}} || {{fnum|142950}}
|-
| 13 || {{fnum|18500}} || {{fnum|0}} || {{fnum|161450}}
|-
| 14 || {{fnum|18500}} || {{fnum|0}} || {{fnum|179950}}
|-
| 15 || {{fnum|21500}} || {{fnum|3000}} || {{fnum|198450}}
|-
| 16 || {{fnum|21500}} || {{fnum|0}} || {{fnum|219950}}
|-
| 17 || {{fnum|21500}} || {{fnum|0}} || {{fnum|241450}}
|-
| 18 || {{fnum|21500}} || {{fnum|0}} || {{fnum|262950}}
|-
| 19 || {{fnum|21500}} || {{fnum|0}} || {{fnum|284450}}
|-
| 20 || {{fnum|25000}} || {{fnum|3500}} || {{fnum|305950}}
|-
| 21 || {{fnum|25000}} || {{fnum|0}} || {{fnum|330950}}
|-
| 22 || {{fnum|25000}} || {{fnum|0}} || {{fnum|355950}}
|-
| 23 || {{fnum|25000}} || {{fnum|0}} || {{fnum|380950}}
|-
| 24 || {{fnum|25000}} || {{fnum|0}} || {{fnum|405950}}
|-
| 25 || ??? || ??? || {{fnum|430950}}
|}
[[Category:Game mechanics]]
2d60aff79f3c19820de1c03f6ed887e247b40df6
1096
1081
2025-08-22T00:48:51Z
Sharparam
284703
/* Overview */ Update level table
wikitext
text/x-wiki
{{stub}}
'''{{PAGENAME}}''' is a measure of a player's experience.
== Overview ==
The level increases by gaining experience points through exploration, defeating [[enemies]], and picking up or interacting with [[items]] or [[lore]] objects.
The amount of experience points required to reach further levels will regularly increase, although not with every level.
Every level up also grants two attribute points that can be used to increase player [[attributes]]. When reaching level 25 you get 6 points instead of 2.
The max level is 25, with each [[NG+]] iteration increasing the cap by 5, to a maximum of 40 in [[NG+|NG+3]].
{| class="wikitable sticky-header hover-highlight" style="text-align: right;"
|-
! scope="col" | Level
! scope="col" | EXP to next
! scope="col" | Cost increase
! scope="col" | Total EXP
! scope="col" | Attribute points
! scope="col" | Total attr points
|-
| 0 || {{fnum|480}} || {{fnum|480}} || {{fnum|0}} || 0 || 0
|-
| 1 || {{fnum|1220}} || {{fnum|740}} || {{fnum|480}} || 2 || 2
|-
| 2 || {{fnum|2250}} || {{fnum|1030}} || {{fnum|1700}} || 2 || 4
|-
| 3 || {{fnum|13500}} || {{fnum|11250}} || {{fnum|3950}} || 2 || 6
|-
| 4 || {{fnum|13500}} || {{fnum|0}} || {{fnum|17450}} || 2 || 8
|-
| 5 || {{fnum|15000}} || {{fnum|1500}} || {{fnum|30950}} || 4 || 12
|-
| 6 || {{fnum|15000}} || {{fnum|0}} || {{fnum|45950}} || 2 || 14
|-
| 7 || {{fnum|15000}} || {{fnum|0}} || {{fnum|60950}} || 2 || 16
|-
| 8 || {{fnum|15000}} || {{fnum|0}} || {{fnum|75950}} || 2 || 18
|-
| 9 || {{fnum|15000}} || {{fnum|0}} || {{fnum|90950}} || 2 || 20
|-
| 10 || {{fnum|18500}} || {{fnum|3500}} || {{fnum|105950}} || 4 || 24
|-
| 11 || {{fnum|18500}} || {{fnum|0}} || {{fnum|124450}} || 2 || 26
|-
| 12 || {{fnum|18500}} || {{fnum|0}} || {{fnum|142950}} || 2 || 28
|-
| 13 || {{fnum|18500}} || {{fnum|0}} || {{fnum|161450}} || 2 || 30
|-
| 14 || {{fnum|18500}} || {{fnum|0}} || {{fnum|179950}} || 2 || 32
|-
| 15 || {{fnum|21500}} || {{fnum|3000}} || {{fnum|198450}} || 4 || 36
|-
| 16 || {{fnum|21500}} || {{fnum|0}} || {{fnum|219950}} || 2 || 38
|-
| 17 || {{fnum|21500}} || {{fnum|0}} || {{fnum|241450}} || 2 || 40
|-
| 18 || {{fnum|21500}} || {{fnum|0}} || {{fnum|262950}} || 2 || 42
|-
| 19 || {{fnum|21500}} || {{fnum|0}} || {{fnum|284450}} || 2 || 44
|-
| 20 || {{fnum|25000}} || {{fnum|3500}} || {{fnum|305950}} || 4 || 48
|-
| 21 || {{fnum|25000}} || {{fnum|0}} || {{fnum|330950}} || 2 || 50
|-
| 22 || {{fnum|25000}} || {{fnum|0}} || {{fnum|355950}} || 2 || 52
|-
| 23 || {{fnum|25000}} || {{fnum|0}} || {{fnum|380950}} || 2 || 54
|-
| 24 || {{fnum|25000}} || {{fnum|0}} || {{fnum|405950}} || 2 || 56
|-
| 25 || {{fnum|103420}} || {{fnum|78420}} || {{fnum|430950}} || 6 || 62
|-
| 26 || {{fnum|103430}} || {{fnum|10}} || {{fnum|534370}} || 3 || 65
|-
| 27 || {{fnum|103430}} || {{fnum|0}} || {{fnum|637800}} || 3 || 68
|-
| 28 || {{fnum|103430}} || {{fnum|0}} || {{fnum|741230}} || 3 || 71
|-
| 29 || {{fnum|103430}} || {{fnum|0}} || {{fnum|844660}} || 3 || 74
|}
[[Category:Game mechanics]]
836d770a69e5b4fe2126732e89aea01c3ac6074e
Category:Attributes
14
708
1083
1082
2025-08-22T00:43:08Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[Category:Game mechanics]]
f2739a7f6d15068b5f220f8cbb0a1aa293521862
Entropy
0
709
1085
1084
2025-08-22T00:43:08Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a property of the player in {{BFF}}.
== Overview ==
Entropy can only be gained from a few sources.
* Dying to a [[Vermillion Knight]] increases entropy by 0.25%.
* Dying during phase 2 of the [[Royal Division Captain Yulia & Vermillion Mirage]] boss fight (after Yulia joins the fight) increases entropy by 0.5%.
Upon reaching 100% entropy, the player's save file is deleted.
[[Category:Game mechanics]]
cda5c4f1fca74bd5447670462ba15ebe07df0b38
Strength
0
710
1087
1086
2025-08-22T00:43:08Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects weapon damage and max weight.
== Overview ==
Strength affects bonus weapon damage, as well as the max weight which affects encumbrance.
The gain to max weight is {{val|450|u=g}} for every attribute point until 45, which is the last to give the increment. Every additional level into strength after that will not increase max weight, so it has a hard cap of {{val|40.5|u=kg}}.
The gain to bonus weapon damage is always 10.8%, but going past 92 shows the total bonus damage as always being 1%. It is unclear if this is just a visual bug or if the bonus damage actually does drop down to 1%.
{| class="wikitable sortable hover-highlight sticky-header-multi mw-collapsible mw-collapsed" style="text-align: right;"
|-
! class="unsortable" scope="col" rowspan="2" | Strength
! class="unsortable" scope="col" rowspan="2" | +Weapon DMG
! class="unsortable" scope="col" rowspan="2" | Max weight (g)
! class="unsortable" scope="col" colspan="2" | Increments
|-
! class="unsortable" scope="col" | +Weapon DMG
! class="unsortable" scope="col" | Max weight (g)
|-
| 0 || 0.0% || {{fnum|20250}} || 0.0% || 0
|-
| 1 || 10.8% || {{fnum|20700}} || 10.8% || 450
|-
| 2 || 21.6% || {{fnum|21150}} || 10.8% || 450
|-
| 3 || 32.4% || {{fnum|21600}} || 10.8% || 450
|-
| 4 || 43.2% || {{fnum|22050}} || 10.8% || 450
|-
| 5 || 54.0% || {{fnum|22500}} || 10.8% || 450
|-
| 6 || 64.8% || {{fnum|22950}} || 10.8% || 450
|-
| 7 || 75.6% || {{fnum|23400}} || 10.8% || 450
|-
| 8 || 86.4% || {{fnum|23850}} || 10.8% || 450
|-
| 9 || 97.2% || {{fnum|24300}} || 10.8% || 450
|-
| 10 || 108.0% || {{fnum|24750}} || 10.8% || 450
|-
| 11 || 118.8% || {{fnum|25200}} || 10.8% || 450
|-
| 12 || 129.6% || {{fnum|25650}} || 10.8% || 450
|-
| 13 || 140.4% || {{fnum|26100}} || 10.8% || 450
|-
| 14 || 151.2% || {{fnum|26550}} || 10.8% || 450
|-
| 15 || 162.0% || {{fnum|27000}} || 10.8% || 450
|-
| 16 || 172.8% || {{fnum|27450}} || 10.8% || 450
|-
| 17 || 183.6% || {{fnum|27900}} || 10.8% || 450
|-
| 18 || 194.4% || {{fnum|28350}} || 10.8% || 450
|-
| 19 || 205.2% || {{fnum|28800}} || 10.8% || 450
|-
| 20 || 216.0% || {{fnum|29250}} || 10.8% || 450
|-
| 21 || 226.8% || {{fnum|29700}} || 10.8% || 450
|-
| 22 || 237.6% || {{fnum|30150}} || 10.8% || 450
|-
| 23 || 248.4% || {{fnum|30600}} || 10.8% || 450
|-
| 24 || 259.2% || {{fnum|31050}} || 10.8% || 450
|-
| 25 || 270.0% || {{fnum|31500}} || 10.8% || 450
|-
| 26 || 280.8% || {{fnum|31950}} || 10.8% || 450
|-
| 27 || 291.6% || {{fnum|32400}} || 10.8% || 450
|-
| 28 || 302.4% || {{fnum|32850}} || 10.8% || 450
|-
| 29 || 313.2% || {{fnum|33300}} || 10.8% || 450
|-
| 30 || 324.0% || {{fnum|33750}} || 10.8% || 450
|-
| 31 || 334.8% || {{fnum|34200}} || 10.8% || 450
|-
| 32 || 345.6% || {{fnum|34650}} || 10.8% || 450
|-
| 33 || 356.4% || {{fnum|35100}} || 10.8% || 450
|-
| 34 || 367.2% || {{fnum|35550}} || 10.8% || 450
|-
| 35 || 378.0% || {{fnum|36000}} || 10.8% || 450
|-
| 36 || 388.8% || {{fnum|36450}} || 10.8% || 450
|-
| 37 || 399.6% || {{fnum|36900}} || 10.8% || 450
|-
| 38 || 410.4% || {{fnum|37350}} || 10.8% || 450
|-
| 39 || 421.2% || {{fnum|37800}} || 10.8% || 450
|-
| 40 || 432.0% || {{fnum|38250}} || 10.8% || 450
|-
| 41 || 442.8% || {{fnum|38700}} || 10.8% || 450
|-
| 42 || 453.6% || {{fnum|39150}} || 10.8% || 450
|-
| 43 || 464.4% || {{fnum|39600}} || 10.8% || 450
|-
| 44 || 475.2% || {{fnum|40050}} || 10.8% || 450
|-
| 45 || 486.0% || {{fnum|40500}} || 10.8% || 450
|-
| 46 || 496.8% || {{fnum|40500}} || 10.8% || 0
|-
| 47 || 507.6% || {{fnum|40500}} || 10.8% || 0
|-
| 48 || 518.4% || {{fnum|40500}} || 10.8% || 0
|-
| 49 || 529.2% || {{fnum|40500}} || 10.8% || 0
|-
| 50 || 540.0% || {{fnum|40500}} || 10.8% || 0
|-
| 51 || 550.8% || {{fnum|40500}} || 10.8% || 0
|-
| 52 || 561.6% || {{fnum|40500}} || 10.8% || 0
|-
| 53 || 572.4% || {{fnum|40500}} || 10.8% || 0
|-
| 54 || 583.2% || {{fnum|40500}} || 10.8% || 0
|-
| 55 || 594.0% || {{fnum|40500}} || 10.8% || 0
|-
| 56 || 604.8% || {{fnum|40500}} || 10.8% || 0
|-
| 57 || 615.6% || {{fnum|40500}} || 10.8% || 0
|-
| 58 || 626.4% || {{fnum|40500}} || 10.8% || 0
|-
| 59 || 637.2% || {{fnum|40500}} || 10.8% || 0
|-
| 60 || 648.0% || {{fnum|40500}} || 10.8% || 0
|-
| 61 || 658.8% || {{fnum|40500}} || 10.8% || 0
|-
| 62 || 669.6% || {{fnum|40500}} || 10.8% || 0
|-
| 63 || 680.4% || {{fnum|40500}} || 10.8% || 0
|-
| 64 || 691.2% || {{fnum|40500}} || 10.8% || 0
|-
| 65 || 702.0% || {{fnum|40500}} || 10.8% || 0
|-
| 66 || 712.8% || {{fnum|40500}} || 10.8% || 0
|-
| 67 || 723.6% || {{fnum|40500}} || 10.8% || 0
|-
| 68 || 734.4% || {{fnum|40500}} || 10.8% || 0
|-
| 69 || 745.2% || {{fnum|40500}} || 10.8% || 0
|-
| 70 || 756.0% || {{fnum|40500}} || 10.8% || 0
|-
| 71 || 766.8% || {{fnum|40500}} || 10.8% || 0
|-
| 72 || 777.6% || {{fnum|40500}} || 10.8% || 0
|-
| 73 || 788.4% || {{fnum|40500}} || 10.8% || 0
|-
| 74 || 799.2% || {{fnum|40500}} || 10.8% || 0
|-
| 75 || 810.0% || {{fnum|40500}} || 10.8% || 0
|-
| 76 || 820.8% || {{fnum|40500}} || 10.8% || 0
|-
| 77 || 831.6% || {{fnum|40500}} || 10.8% || 0
|-
| 78 || 842.4% || {{fnum|40500}} || 10.8% || 0
|-
| 79 || 853.2% || {{fnum|40500}} || 10.8% || 0
|-
| 80 || 864.0% || {{fnum|40500}} || 10.8% || 0
|-
| 81 || 874.8% || {{fnum|40500}} || 10.8% || 0
|-
| 82 || 885.6% || {{fnum|40500}} || 10.8% || 0
|-
| 83 || 896.4% || {{fnum|40500}} || 10.8% || 0
|-
| 84 || 907.2% || {{fnum|40500}} || 10.8% || 0
|-
| 85 || 918.0% || {{fnum|40500}} || 10.8% || 0
|-
| 86 || 928.8% || {{fnum|40500}} || 10.8% || 0
|-
| 87 || 939.6% || {{fnum|40500}} || 10.8% || 0
|-
| 88 || 950.4% || {{fnum|40500}} || 10.8% || 0
|-
| 89 || 961.2% || {{fnum|40500}} || 10.8% || 0
|-
| 90 || 972.0% || {{fnum|40500}} || 10.8% || 0
|-
| 91 || 982.8% || {{fnum|40500}} || 10.8% || 0
|-
| 92 || 993.6% || {{fnum|40500}} || 10.8% || 0
|}
[[Category:Attributes]]
acf936b03bf018cd91d4c8f8790137535cf71c2d
Agility
0
711
1089
1088
2025-08-22T00:43:08Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects stats related to critical chance, stamina, speed, and boss resistance to arrows.
== Overview ==
Critical chance and melee swing speed both have a hard cap at 100. The hard caps for other stats can be seen in the table when their increment amount drops to zero.
<!--<div class="noresize">-->
{| class="wikitable hover-highlight mw-collapsible mw-collapsed sortable sticky-header-multi" style="text-align: right;"
|-
! class="unsortable" scope="col" rowspan="2" | Agility
! class="unsortable" scope="col" rowspan="2" | Crit chance
! class="unsortable" scope="col" rowspan="2" | Stamina
! class="unsortable" scope="col" rowspan="2" | Stam delay
! class="unsortable" scope="col" rowspan="2" | Move speed
! class="unsortable" scope="col" rowspan="2" | Melee swing speed
! class="unsortable" scope="col" rowspan="2" | Range wep draw spd pen
! class="unsortable" scope="col" rowspan="2" | Boss arrow res reduction
! class="unsortable" scope="col" colspan="7" | Increments
|-
! class="unsortable" scope="col" | Crit chance
! class="unsortable" scope="col" | Stamina
! class="unsortable" scope="col" | Stam delay
! class="unsortable" scope="col" | Move speed
! class="unsortable" scope="col" | Melee swing speed
! class="unsortable" scope="col" | Range wep draw spd pen
! class="unsortable" scope="col" | Boss arrow res reduction
|-
| 0 || 0.00% || 105 || 1.90 || 100.00% || 100.0% || 25.00% || 0% || 0.00% || 0 || 0.00 || 0.00% || 0.0% || 0.00% || 0%
|-
| 1 || 0.00% || 105 || 1.90 || 100.00% || 100.0% || 23.89% || 1% || 0.00% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 2 || 0.25% || 105 || 1.90 || 100.00% || 100.0% || 22.78% || 2% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 3 || 0.50% || 105 || 1.90 || 100.00% || 100.0% || 21.67% || 3% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 4 || 0.75% || 105 || 1.90 || 100.00% || 100.0% || 20.56% || 4% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 5 || 1.00% || 105 || 1.90 || 100.00% || 100.0% || 19.45% || 5% || 0.25% || 0 || 0.00 || 0.00% || 0.0% || 1.11% || 1%
|-
| 6 || 1.50% || 107 || 1.89 || 100.00% || 100.0% || 18.34% || 6% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 7 || 2.00% || 109 || 1.88 || 100.00% || 100.0% || 17.23% || 7% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 8 || 2.50% || 111 || 1.87 || 100.00% || 100.0% || 16.12% || 8% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 9 || 3.00% || 113 || 1.86 || 100.00% || 100.0% || 15.01% || 9% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 10 || 3.50% || 115 || 1.85 || 100.00% || 100.0% || 13.90% || 10% || 0.50% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 11 || 4.10% || 117 || 1.84 || 100.00% || 100.0% || 12.79% || 11% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 12 || 4.70% || 119 || 1.83 || 100.00% || 100.0% || 11.68% || 12% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 13 || 5.30% || 121 || 1.82 || 100.00% || 100.0% || 10.57% || 13% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 14 || 5.90% || 123 || 1.81 || 100.00% || 100.0% || 9.46% || 14% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 15 || 6.50% || 125 || 1.80 || 100.00% || 100.0% || 8.35% || 15% || 0.60% || 2 || 0.01 || 0.00% || 0.0% || 1.11% || 1%
|-
| 16 || 9.07% || 127 || 1.79 || 100.17% || 100.5% || 7.24% || 16% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 17 || 11.64% || 129 || 1.78 || 100.34% || 101.0% || 6.13% || 17% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 18 || 14.21% || 131 || 1.77 || 100.51% || 101.5% || 5.02% || 18% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 19 || 16.78% || 133 || 1.76 || 100.68% || 102.0% || 3.91% || 19% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 20 || 19.35% || 135 || 1.75 || 100.85% || 102.5% || 2.80% || 20% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 21 || 21.92% || 137 || 1.74 || 101.02% || 103.0% || 1.69% || 21% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 22 || 24.49% || 139 || 1.73 || 101.19% || 103.5% || 0.58% || 22% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 23 || 27.06% || 141 || 1.72 || 101.36% || 104.0% || -0.53% || 23% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 24 || 29.63% || 143 || 1.71 || 101.53% || 104.5% || -1.64% || 24% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 25 || 32.20% || 145 || 1.70 || 101.70% || 105.0% || -2.75% || 25% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 26 || 34.77% || 147 || 1.69 || 101.87% || 105.5% || -3.86% || 26% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 27 || 37.34% || 149 || 1.68 || 102.04% || 106.0% || -4.97% || 27% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 28 || 39.91% || 151 || 1.67 || 102.21% || 106.5% || -6.08% || 28% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 29 || 42.48% || 153 || 1.66 || 102.38% || 107.0% || -7.19% || 29% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 30 || 45.05% || 155 || 1.65 || 102.55% || 107.5% || -8.30% || 30% || 2.57% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 31 || 46.05% || 157 || 1.64 || 102.72% || 108.0% || -9.41% || 31% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 32 || 47.05% || 159 || 1.63 || 102.89% || 108.5% || -10.52% || 32% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 33 || 48.05% || 161 || 1.62 || 103.06% || 109.0% || -11.63% || 33% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 34 || 49.05% || 163 || 1.61 || 103.23% || 109.5% || -12.74% || 34% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 35 || 50.05% || 165 || 1.60 || 103.40% || 110.0% || -13.85% || 35% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 36 || 51.05% || 167 || 1.59 || 103.57% || 110.5% || -14.96% || 36% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 37 || 52.05% || 169 || 1.58 || 103.74% || 111.0% || -16.07% || 37% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 38 || 53.05% || 171 || 1.57 || 103.91% || 111.5% || -17.18% || 38% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 39 || 54.05% || 173 || 1.56 || 104.08% || 112.0% || -18.29% || 39% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 40 || 55.05% || 175 || 1.55 || 104.25% || 112.5% || -19.40% || 40% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 41 || 56.05% || 177 || 1.54 || 104.42% || 113.0% || -20.51% || 41% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 42 || 57.05% || 179 || 1.53 || 104.59% || 113.5% || -21.62% || 42% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 43 || 58.05% || 181 || 1.52 || 104.76% || 114.0% || -22.73% || 43% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 44 || 59.05% || 183 || 1.51 || 104.93% || 114.5% || -23.84% || 44% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 45 || 60.05% || 185 || 1.50 || 105.10% || 115.0% || -24.95% || 45% || 1.00% || 2 || 0.01 || 0.17% || 0.5% || 1.11% || 1%
|-
| 46 || 61.05% || 186 || 1.50 || 105.24% || 115.5% || -24.95% || 46% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 47 || 62.05% || 187 || 1.50 || 105.38% || 116.0% || -24.95% || 47% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 48 || 63.05% || 188 || 1.50 || 105.52% || 116.5% || -24.95% || 48% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 49 || 64.05% || 189 || 1.50 || 105.66% || 117.0% || -24.95% || 49% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 50 || 65.05% || 190 || 1.50 || 105.80% || 117.5% || -24.95% || 50% || 1.00% || 1 || 0.00 || 0.14% || 0.5% || 0.00% || 1%
|-
| 51 || 65.45% || 191 || 1.50 || 105.94% || 117.7% || -24.95% || 51% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 52 || 65.85% || 192 || 1.50 || 106.08% || 117.9% || -24.95% || 52% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 53 || 66.25% || 193 || 1.50 || 106.22% || 118.1% || -24.95% || 53% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 54 || 66.65% || 194 || 1.50 || 106.36% || 118.3% || -24.95% || 54% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 55 || 67.05% || 195 || 1.50 || 106.50% || 118.5% || -24.95% || 55% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 56 || 67.45% || 196 || 1.50 || 106.64% || 118.7% || -24.95% || 56% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 57 || 67.85% || 197 || 1.50 || 106.78% || 118.9% || -24.95% || 57% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 58 || 68.25% || 198 || 1.50 || 106.92% || 119.1% || -24.95% || 58% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 59 || 68.65% || 199 || 1.50 || 107.06% || 119.3% || -24.95% || 59% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 60 || 69.05% || 200 || 1.50 || 107.20% || 119.5% || -24.95% || 60% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 61 || 69.45% || 201 || 1.50 || 107.34% || 119.7% || -24.95% || 61% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 62 || 69.85% || 202 || 1.50 || 107.48% || 119.9% || -24.95% || 62% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 63 || 70.25% || 203 || 1.50 || 107.62% || 120.1% || -24.95% || 63% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 64 || 70.65% || 204 || 1.50 || 107.76% || 120.3% || -24.95% || 64% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 65 || 71.05% || 205 || 1.50 || 107.90% || 120.5% || -24.95% || 65% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 66 || 71.45% || 206 || 1.50 || 108.04% || 120.7% || -24.95% || 66% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 67 || 71.85% || 207 || 1.50 || 108.18% || 120.9% || -24.95% || 67% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 68 || 72.25% || 208 || 1.50 || 108.32% || 121.1% || -24.95% || 68% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 69 || 72.65% || 209 || 1.50 || 108.46% || 121.3% || -24.95% || 69% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 70 || 73.05% || 210 || 1.50 || 108.60% || 121.5% || -24.95% || 70% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 71 || 73.45% || 211 || 1.50 || 108.74% || 121.7% || -24.95% || 71% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 72 || 73.85% || 212 || 1.50 || 108.88% || 121.9% || -24.95% || 72% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 73 || 74.25% || 213 || 1.50 || 109.02% || 122.1% || -24.95% || 73% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 74 || 74.65% || 214 || 1.50 || 109.16% || 122.3% || -24.95% || 74% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 75 || 75.05% || 215 || 1.50 || 109.30% || 122.5% || -24.95% || 75% || 0.40% || 1 || 0.00 || 0.14% || 0.2% || 0.00% || 1%
|-
| 76 || 75.25% || 216 || 1.50 || 109.44% || 122.6% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 77 || 75.45% || 217 || 1.50 || 109.58% || 122.7% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 78 || 75.65% || 218 || 1.50 || 109.72% || 122.8% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 79 || 75.85% || 219 || 1.50 || 109.86% || 122.9% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 80 || 76.05% || 220 || 1.50 || 110.00% || 123.0% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.14% || 0.1% || 0.00% || 0%
|-
| 81 || 76.25% || 221 || 1.50 || 110.00% || 123.1% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 82 || 76.45% || 222 || 1.50 || 110.00% || 123.2% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 83 || 76.65% || 223 || 1.50 || 110.00% || 123.3% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 84 || 76.85% || 224 || 1.50 || 110.00% || 123.4% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 85 || 77.05% || 225 || 1.50 || 110.00% || 123.5% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 86 || 77.25% || 226 || 1.50 || 110.00% || 123.6% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 87 || 77.45% || 227 || 1.50 || 110.00% || 123.7% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 88 || 77.65% || 228 || 1.50 || 110.00% || 123.8% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 89 || 77.85% || 229 || 1.50 || 110.00% || 123.9% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 90 || 78.05% || 230 || 1.50 || 110.00% || 124.0% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 91 || 78.25% || 231 || 1.50 || 110.00% || 124.1% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 92 || 78.45% || 232 || 1.50 || 110.00% || 124.2% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 93 || 78.65% || 233 || 1.50 || 110.00% || 124.3% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 94 || 78.85% || 234 || 1.50 || 110.00% || 124.4% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 95 || 79.05% || 235 || 1.50 || 110.00% || 124.5% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 96 || 79.25% || 236 || 1.50 || 110.00% || 124.6% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 97 || 79.45% || 237 || 1.50 || 110.00% || 124.7% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 98 || 79.65% || 238 || 1.50 || 110.00% || 124.8% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 99 || 79.85% || 239 || 1.50 || 110.00% || 124.9% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|-
| 100 || 80.05% || 240 || 1.50 || 110.00% || 125.0% || -24.95% || 75% || 0.20% || 1 || 0.00 || 0.00% || 0.1% || 0.00% || 0%
|}
<!--</div>-->
[[Category:Attributes]]
7a701b76e512860658a8b6ad71e4474cbf3409ce
Attributes
0
712
1091
1090
2025-08-22T00:43:08Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' determine the player's [[stats]].
== Overview ==
Each time the player [[Level|levels up]], they get two points to spend on one of the four attributes.
== Strength ==
{{main|Strength}}
== Agility ==
{{main|Agility}}
== Intelligence ==
{{main|Intelligence}}
== Constitution ==
{{main|Constitution}}
[[Category:Attributes]]
9e68b22348fa67fdf1237f31b0043c8996b44821
Template:Fnum
10
713
1092
2025-08-22T00:44:05Z
Sharparam
284703
Created page with "{{#invoke:Formatnum|main}}<noinclude> {{Documentation}} </noinclude>"
wikitext
text/x-wiki
{{#invoke:Formatnum|main}}<noinclude>
{{Documentation}}
</noinclude>
610b9ebfdb987a06a7ffa7b6c9a99ace22ce370c
Module:Formatnum
828
714
1093
2025-08-22T00:44:58Z
Sharparam
284703
Created page with "local getArgs = require('Module:Arguments').getArgs local gaps = require('Module:Gapnum').gaps local p = {} function p.main(frame) local args = getArgs(frame) return p._main(args) end function p._main(args) local number = args[1] or args.number or '' local prec = args.prec or nil return p.formatNum(number, prec) end function p.formatNum(number, prec) -- Do not alter the specified value when it is not a valid number, return it as is local value = to..."
Scribunto
text/plain
local getArgs = require('Module:Arguments').getArgs
local gaps = require('Module:Gapnum').gaps
local p = {}
function p.main(frame)
local args = getArgs(frame)
return p._main(args)
end
function p._main(args)
local number = args[1] or args.number or ''
local prec = args.prec or nil
return p.formatNum(number, prec)
end
function p.formatNum(number, prec)
-- Do not alter the specified value when it is not a valid number, return it as is
local value = tonumber(number)
if value == nil then
return number
end
return gaps(value, { prec = prec })
end
return p
e262e6249b47c2293a72504f7c619d5a2319f144
Module:Formatnum/doc
828
715
1094
2025-08-22T00:45:21Z
Sharparam
284703
Created page with "== Examples == * <syntaxhighlight lang="wikitext" inline>{{fnum|999999}}</syntaxhighlight> → {{fnum|999999}} * <syntaxhighlight lang="wikitext" inline>{{fnum|999999|prec=2}}</syntaxhighlight> → {{fnum|999999|prec=2}} * <syntaxhighlight lang="wikitext" inline>{{fnum|999999.99|prec=2}}</syntaxhighlight> → {{fnum|999999.99|prec=2}}"
wikitext
text/x-wiki
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{fnum|999999}}</syntaxhighlight> → {{fnum|999999}}
* <syntaxhighlight lang="wikitext" inline>{{fnum|999999|prec=2}}</syntaxhighlight> → {{fnum|999999|prec=2}}
* <syntaxhighlight lang="wikitext" inline>{{fnum|999999.99|prec=2}}</syntaxhighlight> → {{fnum|999999.99|prec=2}}
0052a8d10ce94177ba8324b60420d90b79b8059f
Module:Gapnum
828
716
1095
2025-08-22T00:45:51Z
Sharparam
284703
Created page with "local p = {} local getArgs function p.main(frame) if not getArgs then getArgs = require('Module:Arguments').getArgs end local args = getArgs(frame, {wrappers = 'Template:Gapnum'}) local n = args[1] if not n then error('Parameter 1 is required') elseif not tonumber(n) and not tonumber(n, 36) then -- Validates any number with base ≤ 36 error('Unable to convert "' .. args[1] .. '" to a number') end local gap = args.gap local precision = tonumber(args.p..."
Scribunto
text/plain
local p = {}
local getArgs
function p.main(frame)
if not getArgs then
getArgs = require('Module:Arguments').getArgs
end
local args = getArgs(frame, {wrappers = 'Template:Gapnum'})
local n = args[1]
if not n then
error('Parameter 1 is required')
elseif not tonumber(n) and not tonumber(n, 36) then -- Validates any number with base ≤ 36
error('Unable to convert "' .. args[1] .. '" to a number')
end
local gap = args.gap
local precision = tonumber(args.prec)
return p.gaps(n,{gap=gap,prec=precision})
end
-- Not named p._main so that it has a better function name when required by Module:Val
function p.gaps(n,tbl)
local nstr = tostring(n)
if not tbl then
tbl = {}
end
local gap = tbl.gap or '.25em'
local int_part, frac_part = p.groups(n,tbl.prec)
local ret = mw.html.create('span')
:css('white-space','nowrap')
-- No gap necessary on first group
:wikitext(table.remove(int_part,1))
-- Build int part
for _, v in ipairs(int_part) do
ret:tag('span')
:css('margin-left',gap)
:wikitext(v)
end
if frac_part then
-- The first group after the decimal shouldn't have a gap
ret:wikitext('.' .. table.remove(frac_part,1))
-- Build frac part
for _, v in ipairs(frac_part) do
ret:tag('span')
:css('margin-left',gap)
:wikitext(v)
end
end
return ret
end
-- Creates tables where each element is a different group of the number
function p.groups(num,precision)
local nstr = tostring(num)
if not precision then
precision = -1
else
precision = tonumber(precision)
end
local decimalloc = nstr:find('.', 1, true)
local int_part, frac_part
if decimalloc == nil then
int_part = nstr
if precision > 0 then
frac_part = "0"
end
else
int_part = nstr:sub(1, decimalloc-1)
frac_part = nstr:sub(decimalloc + 1)
end
-- only define ret_i as an empty table, let ret_d stay nil
local ret_i,ret_d = {}
-- Loop to handle most of the groupings; from right to left, so that if a group has less than 3 members, it will be the first group
while int_part:len() > 3 do
-- Insert in first spot, since we're moving backwards
table.insert(ret_i,1,int_part:sub(-3))
int_part = int_part:sub(1,-4)
end
-- handle any left over numbers
if int_part:len() > 0 then
table.insert(ret_i,1,int_part)
end
if precision ~= 0 and frac_part then
ret_d = {}
if precision == -1 then
precision = frac_part:len()
end
-- Reduce the length of the string if required precision is less than actual precision
-- OR
-- Increase it (by adding 0s) if the required precision is more than actual
local offset = precision - frac_part:len()
if offset < 0 then
frac_part = frac_part:sub(1,precision)
elseif offset > 0 then
frac_part = frac_part .. string.rep('0', offset)
end
-- Allow groups of 3 or 2 (3 first)
for v in string.gmatch(frac_part,'%d%d%d?') do
table.insert(ret_d,v)
end
-- Preference for groups of 4 instead of groups of 1 at the end
if #frac_part % 3 == 1 then
if frac_part:len() == 1 then
ret_d = {frac_part}
else
local last_g = ret_d[#ret_d] or ''
last_g = last_g..frac_part:sub(-1)
ret_d[#ret_d] = last_g
end
end
end
return ret_i,ret_d
end
return p
6f8d2352b772fec644235b007ba3793006835986
Template:Val
10
717
1098
1097
2025-08-22T00:55:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<includeonly>{{safesubst:<noinclude/>#invoke:val|main}}</includeonly><noinclude>
{{documentation}}
</noinclude>
de315e9728588de49567fc363ccc28b987b6e298
Module:Val
828
718
1100
1099
2025-08-22T00:55:50Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- For Template:Val, output a number and optional unit.
-- Format options include scientific and uncertainty notations.
local numdot = '.' -- decimal mark (use ',' for Italian)
local numsep = ',' -- group separator (use ' ' for Italian)
local mtext = {
-- Message and other text that should be localized.
['mt-bad-exponent'] = 'exponent parameter (<b>e</b>)',
['mt-parameter'] = 'parameter ',
['mt-not-number'] = 'is not a valid number',
['mt-cannot-range'] = 'cannot use a range if the first parameter includes "e"',
['mt-need-range'] = 'needs a range in parameter 2',
['mt-should-range'] = 'should be a range',
['mt-cannot-with-e'] = 'cannot be used if the first parameter includes "e"',
['mt-not-range'] = 'does not accept a range',
['mt-cannot-e'] = 'cannot use e notation',
['mt-too-many-parameter'] = 'too many parameters',
['mt-need-number'] = 'need a number after the last parameter because it is a range.',
['mt-ignore-parameter4'] = 'Val parameter 4 ignored',
['mt-val-not-supported'] = 'Val parameter "%s=%s" is not supported',
['mt-invalid-scale'] = 'Unit "%s" has invalid scale "%s"',
['mt-both-u-ul'] = 'unit (<b>u</b>) and unit with link (<b>ul</b>) are both specified, only one is allowed.',
['mt-both-up-upl'] = 'unit per (<b>up</b>) and unit per with link (<b>upl</b>) are both specified, only one is allowed.',
}
local data_module = 'Module:Val/units'
local convert_module = 'Module:Convert'
local function valerror(msg, nocat, iswarning)
-- Return formatted message text for an error or warning.
-- Can append "#FormattingError" to URL of a page with a problem to find it.
local anchor = '<span id="FormattingError"></span>'
local body, category
if nocat or mw.title.getCurrentTitle():inNamespaces(1, 2, 3, 5) then
-- No category in Talk, User, User_talk, or Wikipedia_talk.
category = ''
else
category = '[[Category:Pages with incorrect formatting templates use]]'
end
iswarning = false -- problems are infrequent so try showing large error so editor will notice
if iswarning then
body = '<sup class="noprint Inline-Template" style="white-space:nowrap;">' ..
'[[Template:Val|<span title="' ..
msg:gsub('"', '"') ..
'">warning</span>]]</sup>'
else
body = '<strong class="error">' ..
'Error in {{[[Template:val|val]]}}: ' ..
msg ..
'</strong>'
end
return anchor .. body .. category
end
local range_types = {
-- No need for ' ' because nowrap applies to all output.
[","] = ", ",
["by"] = " by ",
["-"] = "–",
["–"] = "–",
["and"] = " and ",
["or"] = " or " ,
["to"] = " to " ,
["x"] = " × ",
["×"] = " × ",
["/"] = "/",
}
local range_repeat_unit = {
-- WP:UNIT wants unit repeated when a "multiply" range is used.
["x"] = true,
["×"] = true,
}
local function extract_item(index, numbers, arg)
-- Extract an item from arg and store the result in numbers[index].
-- If no argument or if argument is valid, return nil (no error);
-- otherwise, return an error message.
-- The stored result is:
-- * a table for a number (empty if there was no specified number); or
-- * a string for range text
-- Input like 1e3 is regarded as invalid for all except argument 1
-- which accepts e notation as an alternative to the 'e' argument.
-- Input group separators are removed.
local which = index
local function fail(msg)
local description
if which == 'e' then
description = mtext['mt-bad-exponent']
else
description = mtext['mt-parameter'] .. which
end
return description .. ' ' .. (msg or mtext['mt-not-number']) .. '.'
end
local result = {}
local range = range_types[arg]
if range then
if type(index) == 'number' and (index % 2 == 0) then
if index == 2 then
if numbers[1] and numbers[1].exp then
return fail(mtext['mt-cannot-range'])
end
numbers.has_ranges = true
else
if not numbers.has_ranges then
return fail(mtext['mt-need-range'])
end
end
numbers[index] = range
if range_repeat_unit[arg] then
-- Any "repeat" range forces unit (if any) to be repeated for all items.
numbers.isrepeat = true
end
return nil
end
return fail(mtext['mt-not-range'])
end
if numbers.has_ranges and type(index) == 'number' and (index % 2 == 0) then
return fail(mtext['mt-should-range'])
end
if index == 'e' then
local e = numbers[1] and numbers[1].exp
if e then
if arg then
return fail(mtext['mt-cannot-with-e'])
end
arg = e
which = 1
end
end
if arg and arg ~= '' then
arg = arg:gsub(numsep, '')
if numdot ~= '.' then
arg = arg:gsub(numdot, '.')
end
if arg:sub(1, 1) == '(' and arg:sub(-1) == ')' then
result.parens = true
arg = arg:sub(2, -2)
end
local a, b = arg:match('^(.+)[Ee](.+)$')
if a then
if index == 1 then
arg = a
result.exp = b
else
return fail(mtext['mt-cannot-e'])
end
end
local isnegative, propersign, prefix
local minus = '−'
prefix, arg = arg:match('^(.-)([%d.]+)$')
local value = tonumber(arg)
if not value then
return fail()
end
if arg:sub(1, 1) == '.' then
arg = '0' .. arg
end
if prefix == '' then
-- Ignore.
elseif prefix == '±' then
-- Display for first number, ignore for others.
if index == 1 then
propersign = '±'
end
elseif prefix == '+' then
propersign = '+'
elseif prefix == '-' or prefix == minus then
propersign = minus
isnegative = true
else
return fail()
end
result.clean = arg
result.sign = propersign or ''
result.value = isnegative and -value or value
end
numbers[index] = result
return nil -- no error
end
local function get_args(numbers, args)
-- Extract arguments and store the results in numbers.
-- Return nothing (no error) if ok; otherwise, return an error message.
for index = 1, 99 do
local which = index
local arg = args[which] -- has been trimmed
if not arg then
which = 'e'
arg = args[which]
end
local msg = extract_item(which, numbers, arg)
if msg then
return msg
end
if which == 'e' then
break
end
if index > 19 then
return mtext['mt-too-many-parameter']
end
end
if numbers.has_ranges and (#numbers % 2 == 0) then
return mtext['mt-need-number']
end
end
local function get_scale(text, ucode)
-- Return the value of text as a number, or throw an error.
-- This supports extremely basic expressions of the form:
-- a / b
-- a ^ b
-- where a and b are numbers or 'pi'.
local n = tonumber(text)
if n then
return n
end
n = text:gsub('pi', math.pi)
for _, op in ipairs({ '/', '^' }) do
local a, b = n:match('^(.-)' .. op .. '(.*)$')
if a then
a = tonumber(a)
b = tonumber(b)
if a and b then
if op == '/' then
return a / b
elseif op == '^' then
return a ^ b
end
end
break
end
end
error(string.format(mtext['mt-invalid-scale'], ucode, text))
end
local function get_builtin_unit(ucode, definitions)
-- Return table of information for the specified built-in unit, or nil if not known.
-- Each defined unit code must be followed by two spaces (not tab characters).
local _, pos = definitions:find('\n' .. ucode .. ' ', 1, true)
if pos then
local endline = definitions:find('%s*\n', pos)
if endline then
local result = {}
local n = 0
local text = definitions:sub(pos + 1, endline - 1):gsub('%s%s+', '\t')
for item in (text .. '\t'):gmatch('(%S.-)\t') do
if item == 'ALIAS' then
result.alias = true
elseif item == 'ANGLE' then
result.isangle = true
result.nospace = true
elseif item == 'NOSPACE' then
result.nospace = true
elseif item == 'SI' then
result.si = true
else
n = n + 1
if n == 1 then
local link, symbol = item:match('^%[%[([^|]+)|(.+)%]%]$')
if link then
result.symbol = symbol
result.link = link
n = 2
else
result.symbol = item
end
elseif n == 2 then
result.link = item
elseif n == 3 then
result.scale_text = item
result.scale = get_scale(item, ucode)
else
result.more_ignored = item
break
end
end
end
if result.si then
local s = result.symbol
if ucode == 'mc' .. s or ucode == 'mu' .. s then
result.ucode = 'µ' .. s -- unit code for convert should be this
end
end
if n >= 2 or (n >= 1 and result.alias) then
return result
end
-- Ignore invalid definition, treating it as a comment.
end
end
end
local function convert_lookup(ucode, value, scaled_top, want_link, si, options)
local lookup = require(convert_module)._unit
return lookup(ucode, {
value = value,
scaled_top = scaled_top,
link = want_link,
si = si,
sort = options.sortable,
})
end
local function get_unit(ucode, value, scaled_top, options)
local want_link = options.want_link
if scaled_top then
want_link = options.want_per_link
end
local data = mw.loadData(data_module)
local result = options.want_longscale and
get_builtin_unit(ucode, data.builtin_units_long_scale) or
get_builtin_unit(ucode, data.builtin_units)
local si, use_convert
if result then
if result.alias then
ucode = result.symbol
use_convert = true
end
if result.scale then
-- Setting si means convert will use the unit as given, and the sort key
-- will be calculated from the value without any extra scaling that may
-- occur if convert found the unit code. For example, if val defines the
-- unit 'year' with a scale and if si were not set, convert would also apply
-- its own scale because convert knows that a year is 31,557,600 seconds.
si = { result.symbol, result.link }
value = value * result.scale
end
if result.si then
ucode = result.ucode or ucode
si = { result.symbol, result.link }
use_convert = true
end
else
result = {}
use_convert = true
end
local convert_unit = convert_lookup(ucode, value, scaled_top, want_link, si, options)
result.sortkey = convert_unit.sortspan
if use_convert then
result.text = convert_unit.text
result.scaled_top = convert_unit.scaled_value
else
if want_link then
result.text = '[[' .. result.link .. '|' .. result.symbol .. ']]'
else
result.text = result.symbol
end
result.scaled_top = value
end
return result
end
local function makeunit(value, options)
-- Return table of information for the requested unit and options, or
-- return nil if no unit.
options = options or {}
local unit
local ucode = options.u
local percode = options.per
if ucode then
unit = get_unit(ucode, value, nil, options)
elseif percode then
unit = { nospace = true, scaled_top = value }
else
return nil
end
local text = unit.text or ''
local sortkey = unit.sortkey
if percode then
local function bracketed(code, text)
return code:find('[*./]') and '(' .. text .. ')' or text
end
local perunit = get_unit(percode, 1, unit.scaled_top, options)
text = (ucode and bracketed(ucode, text) or '') ..
'/' .. bracketed(percode, perunit.text)
sortkey = perunit.sortkey
end
if not (unit.nospace or options.nospace) then
text = ' ' .. text
end
return { text = text, isangle = unit.isangle, sortkey = sortkey }
end
local function list_units(mode)
-- Return wikitext to list the built-in units.
-- A unit code should not contain wikimarkup so don't bother escaping.
local data = mw.loadData(data_module)
local definitions = data.builtin_units .. data.builtin_units_long_scale
local last_was_blank = true
local n = 0
local result = {}
local function add(line)
if line == '' then
last_was_blank = true
else
if last_was_blank and n > 0 then
n = n + 1
result[n] = ''
end
last_was_blank = false
n = n + 1
result[n] = line
end
end
local si_prefixes = {
-- These are the prefixes recognized by convert; u is accepted for micro.
y = 'y',
z = 'z',
a = 'a',
f = 'f',
p = 'p',
n = 'n',
u = 'µ',
['µ'] = 'µ',
m = 'm',
c = 'c',
d = 'd',
da = 'da',
h = 'h',
k = 'k',
M = 'M',
G = 'G',
T = 'T',
P = 'P',
E = 'E',
Z = 'Z',
Y = 'Y',
}
local function is_valid(ucode, unit)
if unit and not unit.more_ignored then
assert(type(unit.symbol) == 'string' and unit.symbol ~= '')
if unit.alias then
if unit.link or unit.scale_text or unit.si then
return false
end
end
if unit.si then
if unit.scale_text then
return false
end
ucode = unit.ucode or ucode
local base = unit.symbol
if ucode == base then
unit.display = base
return true
end
local plen = #ucode - #base
if plen > 0 then
local prefix = si_prefixes[ucode:sub(1, plen)]
if prefix and ucode:sub(plen + 1) == base then
unit.display = prefix .. base
return true
end
end
else
unit.display = unit.symbol
return true
end
end
return false
end
local lookup = require(convert_module)._unit
local function show_convert(ucode, unit)
-- If a built-in unit defines a scale or sets the SI flag, any unit defined in
-- convert is not used (the scale or SI prefix's scale is used for a sort key).
-- If there is no scale or SI flag, and the unit is not defined in convert,
-- the sort key may not be correct; this allows such units to be identified.
if not (unit.si or unit.scale_text) then
if mode == 'convert' then
unit.show = not lookup(unit.alias and unit.symbol or ucode).unknown
unit.show_text = 'CONVERT'
elseif mode == 'unknown' then
unit.show = lookup(unit.alias and unit.symbol or ucode).unknown
unit.show_text = 'UNKNOWN'
elseif not unit.alias then
-- Show convert's scale in square brackets ('[1]' for an unknown unit).
-- Don't show scale for an alias because it's misleading for temperature
-- and an alias is probably not useful for anything else.
local scale = lookup(ucode, {value=1, sort='on'}).scaled_value
if type(scale) == 'number' then
scale = string.format('%.5g', scale):gsub('e%+?(%-?)0*(%d+)', 'e%1%2')
else
scale = '?'
end
unit.show = true
unit.show_text = '[' .. scale .. ']'
end
end
end
for line in definitions:gmatch('([^\n]*)\n') do
local pos, _ = line:find(' ', 1, true)
if pos then
local ucode = line:sub(1, pos - 1)
local unit = get_builtin_unit(ucode, '\n' .. line .. '\n')
if is_valid(ucode, unit) then
show_convert(ucode, unit)
local flags, text
if unit.alias then
text = unit.symbol
else
text = '[[' .. unit.link .. '|' .. unit.display .. ']]'
end
if unit.isangle then
unit.nospace = nil -- don't show redundant flag
end
for _, f in ipairs({
{ 'alias', 'ALIAS' },
{ 'isangle', 'ANGLE' },
{ 'nospace', 'NOSPACE' },
{ 'si', 'SI' },
{ 'scale_text', unit.scale_text },
{ 'show', unit.show_text },
}) do
if unit[f[1]] then
local t = f[2]
if t:match('^%u+$') then
t = '<small>' .. t .. '</small>'
end
if flags then
flags = flags .. ' ' .. t
else
flags = t
end
end
end
if flags then
text = text .. ' • ' .. flags
end
add(ucode .. ' = ' .. text .. '<br />')
else
add(line .. ' ◆ <b>invalid definition</b><br />')
end
else
add(line)
end
end
return table.concat(result, '\n')
end
local delimit_groups = require('Module:Gapnum').groups
local function delimit(sign, numstr, fmt)
-- Return sign and numstr (unsigned digits or numdot only) after formatting.
-- Four-digit integers are not formatted with gaps.
fmt = (fmt or ''):lower()
if fmt == 'none' or (fmt == '' and #numstr == 4 and numstr:match('^%d+$')) then
return sign .. numstr
end
-- Group number by integer and decimal parts.
-- If there is no decimal part, delimit_groups returns only one table.
local ipart, dpart = delimit_groups(numstr)
local result
if fmt == 'commas' then
result = sign .. table.concat(ipart, numsep)
if dpart then
result = result .. numdot .. table.concat(dpart)
end
else
-- Delimit with a small gap by default.
local groups = {}
groups[1] = table.remove(ipart, 1)
for _, v in ipairs(ipart) do
table.insert(groups, '<span style="margin-left:.25em;">' .. v .. '</span>')
end
if dpart then
table.insert(groups, numdot .. (table.remove(dpart, 1) or ''))
for _, v in ipairs(dpart) do
table.insert(groups, '<span style="margin-left:.25em;">' .. v .. '</span>')
end
end
result = sign .. table.concat(groups)
end
return result
end
local function sup_sub(sup, sub, align)
-- Return the same result as Module:Su except val defaults to align=right.
if align == 'l' or align == 'left' then
align = 'left'
elseif align == 'c' or align == 'center' then
align = 'center'
else
align = 'right'
end
return '<span style="display:inline-block;margin-bottom:-0.3em;vertical-align:-0.4em;line-height:1.2em;font-size:85%;text-align:' ..
align .. ';">' .. sup .. '<br />' .. sub .. '</span>'
end
local function range_text(items, unit_table, options)
local fmt = options.fmt
local nend = items.nend or ''
if items.isrepeat or unit_table.isangle then
nend = nend .. unit_table.text
end
local text = ''
for i = 1, #items do
if i % 2 == 0 then
text = text .. items[i]
else
text = text .. delimit(items[i].sign, items[i].clean, fmt) .. nend
end
end
return text
end
local function uncertainty_text(uncertainty, unit_table, options)
local angle, text, need_parens
if unit_table.isangle then
angle = unit_table.text
end
local upper = uncertainty.upper or {}
local lower = uncertainty.lower or {}
local uncU = upper.clean
if uncU then
local fmt = options.fmt
local uncL = lower.clean
if uncL then
uncU = delimit('+', uncU, fmt) .. (upper.errend or '')
uncL = delimit('−', uncL, fmt) .. (lower.errend or '')
if angle then
uncU = uncU .. angle
uncL = uncL .. angle
end
text = (angle or '') ..
'<span style="margin-left:0.3em;">' ..
sup_sub(uncU, uncL, options.align) ..
'</span>'
else
if upper.parens then
text = '(' .. uncU .. ')' -- old template did not delimit
else
text = (angle or '') ..
'<span style="margin-left:0.225em;margin-right:0.225em;">±</span>' ..
delimit('', uncU, fmt)
need_parens = true
end
if uncertainty.errend then
text = text .. uncertainty.errend
end
if angle then
text = text .. angle
end
end
else
if angle then
text = angle
end
end
return text, need_parens
end
local function _main(values, unit_spec, options)
if options.sandbox then
data_module = data_module .. '/sandbox'
convert_module = convert_module .. '/sandbox'
end
local action = options.action
if action then
if action == 'list' then
-- Kludge: am using the align parameter (a=xxx) for type of list.
return list_units(options.align)
end
return valerror('invalid action "' .. action .. '".', options.nocat)
end
local number = values.number or (values.numbers and values.numbers[1]) or {}
local e_10 = options.e or {}
local novalue = (number.value == nil and e_10.clean == nil)
local fmt = options.fmt
local want_sort = true
local sortable = options.sortable
if sortable == 'off' or (sortable == nil and novalue) then
want_sort = false
elseif sortable == 'debug' then
-- Same as sortable = 'on' but the sort key is displayed.
else
sortable = 'on'
end
local sort_value = 1
if want_sort then
sort_value = number.value or 1
if e_10.value and sort_value ~= 0 then
-- The 'if' avoids {{val|0|e=1234}} giving an invalid sort_value due to overflow.
sort_value = sort_value * 10^e_10.value
end
end
local unit_table = makeunit(sort_value, {
u = unit_spec.u,
want_link = unit_spec.want_link,
per = unit_spec.per,
want_per_link = unit_spec.want_per_link,
nospace = novalue,
want_longscale = unit_spec.want_longscale,
sortable = sortable,
})
local sortkey
if unit_table then
if want_sort then
sortkey = unit_table.sortkey
end
else
unit_table = { text = '' }
if want_sort then
sortkey = convert_lookup('dummy', sort_value, nil, nil, nil, { sortable = sortable }).sortspan
end
end
local final_unit = unit_table.isangle and '' or unit_table.text
local e_text, n_text, need_parens
local uncertainty = values.uncertainty
if uncertainty then
if number.clean then
n_text = delimit(number.sign, number.clean, fmt) .. (number.nend or '')
local text
text, need_parens = uncertainty_text(uncertainty, unit_table, options)
if text then
n_text = n_text .. text
end
else
n_text = ''
end
else
if values.numbers.isrepeat then
final_unit = ''
end
n_text = range_text(values.numbers, unit_table, options)
need_parens = true
end
if e_10.clean then
if need_parens then
n_text = '(' .. n_text .. ')'
end
e_text = '10<sup>' .. delimit(e_10.sign, e_10.clean, fmt) .. '</sup>'
if number.clean then
e_text = '<span style="margin-left:0.25em;margin-right:0.15em;">×</span>' .. e_text
end
else
e_text = ''
end
local result =
(sortkey or '') ..
(options.prefix or '') ..
n_text ..
e_text ..
final_unit ..
(options.suffix or '')
if result ~= '' then
result = '<span class="nowrap">' .. result .. '</span>'
end
return result .. (options.warning or '')
end
local function check_parameters(args, has_ranges, nocat)
-- Return warning text for the first problem parameter found, or nothing if ok.
local whitelist = {
a = true,
action = true,
debug = true,
e = true,
['end'] = true,
errend = true,
['+errend'] = true,
['-errend'] = true,
fmt = true,
['long scale'] = true,
long_scale = true,
longscale = true,
nocategory = true,
p = true,
s = true,
sortable = true,
u = true,
ul = true,
up = true,
upl = true,
}
for k, v in pairs(args) do
if type(k) == 'string' and not whitelist[k] then
local warning = string.format(mtext['mt-val-not-supported'], k, v)
return valerror(warning, nocat, true)
end
end
if not has_ranges and args[4] then
return valerror(mtext['mt-ignore-parameter4'], nocat, true)
end
end
local function main(frame)
local getArgs = require('Module:Arguments').getArgs
local args = getArgs(frame, {wrappers = { 'Template:Val' }})
local nocat = args.nocategory
local numbers = {} -- table of number tables, perhaps with range text
local msg = get_args(numbers, args)
if msg then
return valerror(msg, nocat)
end
if args.u and args.ul then
return valerror(mtext['mt-both-u-ul'], nocat)
end
if args.up and args.upl then
return valerror(mtext['mt-both-up-upl'], nocat)
end
local values
if numbers.has_ranges then
-- Multiple values with range separators but no uncertainty.
numbers.nend = args['end']
values = {
numbers = numbers,
}
else
-- A single value with optional uncertainty.
local function setfield(i, dst, src)
local v = args[src]
if v then
if numbers[i] then
numbers[i][dst] = v
else
numbers[i] = { [dst] = v }
end
end
end
setfield(1, 'nend', 'end')
setfield(2, 'errend', '+errend')
setfield(3, 'errend', '-errend')
values = {
number = numbers[1],
uncertainty = {
upper = numbers[2],
lower = numbers[3],
errend = args.errend,
}
}
end
local unit_spec = {
u = args.ul or args.u,
want_link = args.ul ~= nil,
per = args.upl or args.up,
want_per_link = args.upl ~= nil,
want_longscale = (args.longscale or args.long_scale or args['long scale']) == 'on',
}
local options = {
action = args.action,
align = args.a,
e = numbers.e,
fmt = args.fmt,
nocat = nocat,
prefix = args.p,
sandbox = string.find(frame:getTitle(), 'sandbox', 1, true) ~= nil,
sortable = args.sortable or (args.debug == 'yes' and 'debug' or nil),
suffix = args.s,
warning = check_parameters(args, numbers.has_ranges, nocat),
}
return _main(values, unit_spec, options)
end
return { main = main, _main = _main }
6a50e544e78223a89c0b012cb5fc6de86419edf8
Module:Val/units
828
719
1102
1101
2025-08-22T00:55:50Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Definitions for units known to val
-- File format is two strings and a return statement with them in it:
-- string in quotes [=[ ... builtin_units ... ]=].
-- string in quotes [=[ ... builtin_units_long_scale ... ]=].
-- First string, builtin_units, is short-scale, second string is long scale.
-- Entry format:
-- One record per line, starting in first column, having 2-4 fields.
-- Field separator: two or more spaces
-- Between first and second fields: two or more spaces
-- Between all other fields: two or more spaces, or one or more tabs
-- Entries without two spaces in them are ignored.
-- There must be a blank line before the first entry and after the last.
-- I.e. the first two and last two characters of the string must be newlines.
-- Format of entry. Two record types:
--
-- One record type is a wikilink:
-- Unit-code [[ pagename | Symbol-accepts-HTML-only ]]
-- Text-field separator is still two spaces. Two spaces not allowed in wikilink.
--
-- The other record type is all fields:
-- Unit-code symbol-accepts-HTML-only pagename#section-OK
--
-- Plus there is an optional field that goes at the end after two or more spaces.
-- Whether it is a number or an equation or the letters SI,
-- any of these three has the same function: a wikitable sorting "scale".
-- It is for sorting, and it works for either record type.
-- Difference is SI can't accept HTML. But SI correctly scales any SI prefix.
-- (Optional fields ALIAS and NOSPACE and ANGLE are for advanced users.)
-- "Invalid unit" error:
-- Using SI requires that the symbol equal unit-code, so never allows HTML.
-- Any difference between SI or symbol must be an SI prefix, such as k, M, or G.
-- A space at the end of an entry is an error. No space at each EOL.
local builtin_units = [=[
== Test ==
Foo [[Hz|<samp>Foo</samp>]]
Baz [[Hertz|baz<sub>0</sub>]]
Baz [[Kelvins|baz<sub>0</sub>]]
Bar [[Foobar|bar<abbr title="super duper">0</abbr>]]
quux [[Foobar|<span title="super duper 2">bar0</span>]]
== Unsorted units ==
c0 [[Speed of light#Numerical value, notation, and units|''c''<sub>0</sub>]]
lbf [[Pound (force)|<span title="pound-force">lb<sub>F</sub></span>]]
N.s [[Newton-second|N⋅s]]
J.K-1 [[Joule per kelvin|J⋅K<sup>−1</sup>]]
C.mol-1 [[Faraday constant|C⋅mol<sup>−1</sup>]]
C/mol [[Faraday constant|C/mol]]
C.kg-1 [[Roentgen (unit)|C⋅kg<sup>−1</sup>]]
C/kg [[Roentgen (unit)|C/kg]]
F.m-1 [[vacuum permittivity|F⋅m<sup>−1</sup>]]
F/m [[vacuum permittivity|F/m]]
e [[Elementary charge|''e'']]
kB [[Kilobyte|kB]] 8e3
KB [[Kilobyte|KB]] 8e3
MB [[Megabyte|MB]] 8e6
GB [[Gigabyte|GB]] 8e9
TB [[Terabyte|TB]] 8e12
lx [[Lux (unit)|lx]]
nat [[nat (unit)|nat]]
== Time and frequency ==
byte/s [[Data rate units|byte/s]] 8
kB/s [[Data rate units#Kilobyte per second|<span title="Kilobytes per second">kB/s</span>]] 8e3
MB/s [[Data rate units#Megabyte per second|<span title="Megabytes per second">MB/s</span>]] 8e6
GB/s [[Data rate units#Gigabyte per second|<span title="Gigabytes per second">GB/s</span>]] 8e9
TB/s [[Data rate units#Terabyte per second|<span title="Terabytes per second">TB/s</span>]] 8e12
bit/s [[Bit per second|bit/s]] 1
bps [[Bit per second|bit/s]] 1
kbit/s [[Kilobit per second|kbit/s]] 1e3
Mbit/s [[Megabit per second|Mbit/s]] 1e6
Gbit/s [[Gigabit per second|Gbit/s]] 1e9
Tbit/s [[Terabit per second|Tbit/s]] 1e12
kT/s [[Transfer (computing)|<span title="Kilotransfers per second">kT/s</span>]] 1e3
MT/s [[Transfer (computing)|<span title="Megatransfers per second">MT/s</span>]] 1e6
GT/s [[Transfer (computing)|<span title="Gigatransfers per second">GT/s</span>]] 1e9
year [[Year|year]] 31557600
years [[Year|years]] 31557600
yr [[Year#Symbols and abbreviations|yr]] 31557600
y [[Year|y]] 31557600
a [[Annum|a]] 31557600
Ga [[Gigaannum|Ga]] 31557600000000000
Ma [[Megaannum|Ma]] 31557600000000
ka [[Kiloannum|ka]] 31557600000
kyr [[kyr|kyr]] 31557600000
kya [[kyr|kya]] 31557600000
myr [[myr|myr]] 31557600000000
mya [[Mya (unit)|mya]] 31557600000000
byr [[Billion years|byr]] 31557600000000000
bya [[Billion years ago|bya]] 31557600000000000
Gyr [[billion years|Gyr]] 31557600000000000
BP [[Before present|BP]]
uBP [[Radiocarbon dating#Calibration|<sup>14</sup>C yr BP]]
BC [[Before Christ|BC]] -1
AD [[Anno Domini|AD]] 1
BCE [[Before the Common Era|BCE]] -1
CE [[Common Era|CE]] 1
JD [[Julian date|JD]] 1
MJD [[Modified Julian date|MJD]] 1
s-1 [[Second|s<sup>−1</sup>]]
s-2 [[Second|s<sup>−2</sup>]]
s2 [[Second|s<sup>2</sup>]]
s [[Second|s]] SI
as [[Attosecond|s]] SI
cs [[Second|s]] SI
das [[Second|s]] SI
ds [[Second|s]] SI
Es [[Second|s]] SI
fs [[Femtosecond|s]] SI
Gs [[Second|s]] SI
hs [[Second|s]] SI
ks [[Second|s]] SI
ms [[Millisecond|s]] SI
µs [[Microsecond|s]] SI
us [[Microsecond|s]] SI
Ms [[Second|s]] SI
ns [[Nanosecond|s]] SI
ps [[Picosecond|s]] SI
Ps [[Second|s]] SI
Ts [[Second|s]] SI
Ys [[Second|s]] SI
ys [[Yoctosecond|s]] SI
Zs [[Second|s]] SI
zs [[Zeptosecond|s]] SI
Hz [[Hertz|Hz]] SI
aHz [[Hertz|Hz]] SI
cHz [[Hertz|Hz]] SI
daHz [[Hertz|Hz]] SI
dHz [[Hertz|Hz]] SI
EHz [[Hertz|Hz]] SI
fHz [[Hertz|Hz]] SI
hHz [[Hertz|Hz]] SI
GHz [[Gigahertz|Hz]] SI
kHz [[Kilohertz|Hz]] SI
MHz [[Megahertz|Hz]] SI
mHz [[Hertz|Hz]] SI
uHz [[Hertz|Hz]] SI
µHz [[Hertz|Hz]] SI
nHz [[Hertz|Hz]] SI
pHz [[Hertz|Hz]] SI
PHz [[Hertz|Hz]] SI
THz [[Hertz|Hz]] SI
yHz [[Hertz|Hz]] SI
YHz [[Hertz|Hz]] SI
zHz [[Hertz|Hz]] SI
ZHz [[Hertz|Hz]] SI
ips [[Inch per second|ips]]
== Length, area, volume ==
Å3 [[Ångström|Å<sup>3</sup>]]
fb-1 [[Barn (unit)#Inverse femtobarn|fb<sup>−1</sup>]]
m-1 [[Metre|m<sup>−1</sup>]]
m-2 [[Square metre|m<sup>−2</sup>]]
m-3 [[Cubic metre|m<sup>−3</sup>]]
km2 [[Square kilometre|km<sup>2</sup>]]
km3 [[Cubic kilometre|km<sup>3</sup>]]
µm2 [[Square metre|µm<sup>2</sup>]]
um2 [[Square metre|µm<sup>2</sup>]]
am2 [[Square metre|am<sup>2</sup>]]
cm2 [[Square centimetre|cm<sup>2</sup>]]
dam2 [[Square metre|dam<sup>2</sup>]]
dm2 [[Square metre|dm<sup>2</sup>]]
Em2 [[Square metre|Em<sup>2</sup>]]
fm2 [[Square metre|fm<sup>2</sup>]]
Gm2 [[Square metre|Gm<sup>2</sup>]]
hm2 [[Square metre|hm<sup>2</sup>]]
mm2 [[Square metre|mm<sup>2</sup>]]
Mm2 [[Square metre|Mm<sup>2</sup>]]
nm2 [[Square metre|nm<sup>2</sup>]]
pm2 [[Square metre|pm<sup>2</sup>]]
Pm2 [[Square metre|Pm<sup>2</sup>]]
Tm2 [[Square metre|Tm<sup>2</sup>]]
ym2 [[Square metre|ym<sup>2</sup>]]
Ym2 [[Square metre|Ym<sup>2</sup>]]
zm2 [[Square metre|zm<sup>2</sup>]]
Zm2 [[Square metre|Zm<sup>2</sup>]]
gal [[Gallon|gal]]
Gal [[Gal (unit)|Gal]]
uGal [[Gal (unit)|µGal]]
µGal [[Gal (unit)|µGal]]
mGal [[Gal (unit)|mGal]]
b [[Barn (unit)|b]] SI
ab [[Barn (unit)|b]] SI
cb [[Barn (unit)|b]] SI
dab [[Barn (unit)|b]] SI
db [[Barn (unit)|b]] SI
Eb [[Barn (unit)|b]] SI
fb [[Barn (unit)|b]] SI
Gb [[Barn (unit)|b]] SI
hb [[Barn (unit)|b]] SI
kb [[Barn (unit)|b]] SI
mb [[Barn (unit)|b]] SI
µb [[Barn (unit)|b]] SI
ub [[Barn (unit)|b]] SI
Mb [[Barn (unit)|b]] SI
nb [[Barn (unit)|b]] SI
pb [[Barn (unit)|b]] SI
Pb [[Barn (unit)|b]] SI
Tb [[Barn (unit)|b]] SI
Yb [[Barn (unit)|b]] SI
yb [[Barn (unit)|b]] SI
Zb [[Barn (unit)|b]] SI
zb [[Barn (unit)|b]] SI
== Velocity and acceleration ==
m.s-2 [[Metre per second squared|m⋅s<sup>−2</sup>]]
m/s2 [[Metre per second squared|m/s<sup>2</sup>]]
m.s-1 [[Metre per second|m⋅s<sup>−1</sup>]]
m/s [[Metre per second|m/s]]
km.s-1 [[Metre per second|km⋅s<sup>−1</sup>]]
km/s [[Metre per second|km/s]]
== Mass and energy ==
lbm [[Pound (mass)|<span title="pound-mass">lb<sub>m</sub></span>]]
uJ [[Joule|µJ]]
J.s [[Joule-second|J⋅s]]
kWh [[Kilowatt hour|kWh]]
kW.h [[Kilowatt hour|kW⋅h]]
J/C [[Volt|J/C]]
J/kg [[Joule|J/kg]]
Da [[Dalton (unit)|Da]] SI
EDa [[Dalton (unit)|Da]] SI
PDa [[Dalton (unit)|Da]] SI
TDa [[Dalton (unit)|Da]] SI
GDa [[Dalton (unit)|Da]] SI
MDa [[Dalton (unit)|Da]] SI
kDa [[Dalton (unit)|Da]] SI
mDa [[Dalton (unit)|Da]] SI
uDa [[Dalton (unit)|Da]] SI
μDa [[Dalton (unit)|Da]] SI
nDa [[Dalton (unit)|Da]] SI
pDa [[Dalton (unit)|Da]] SI
fDa [[Dalton (unit)|Da]] SI
aDa [[Dalton (unit)|Da]] SI
g [[Gram|g]] SI
ag [[Attogram|g]] SI
cg [[Centigram|g]] SI
dag [[Gram|g]] SI
dg [[Decigram|g]] SI
Eg [[Exagram|g]] SI
fg [[Femtogram|g]] SI
Gg [[Gigagram|g]] SI
hg [[Kilogram#SI multiples|g]] SI
kg [[Kilogram|g]] SI
mcg [[Microgram|g]] SI
Mg [[Megagram|g]] SI
mg [[Milligram|g]] SI
ug [[Microgram|g]] SI
µg [[Microgram|g]] SI
ng [[Nanogram|g]] SI
Pg [[Petagram|g]] SI
pg [[Picogram|g]] SI
Tg [[Tonne|g]] SI
yg [[Yoctogram|g]] SI
Yg [[Yottagram|g]] SI
zg [[Zeptogram|g]] SI
Zg [[Zettagram|g]] SI
== Pressure and density ==
psi [[Pounds per square inch|psi]]
g.cm-3 [[Gram per cubic centimetre|g⋅cm<sup>−3</sup>]]
g/cm3 [[Gram per cubic centimetre|g/cm<sup>3</sup>]]
kg.m-3 [[Kilogram per cubic metre|kg⋅m<sup>−3</sup>]]
kg/m3 [[Kilogram per cubic metre|kg/m<sup>3</sup>]]
kg/cm3 [[Density#Formula and common units|kg/cm<sup>3</sup>]]
g/L [[Gram per litre|g/L]]
g/l [[Gram per litre|g/l]]
mcg/dL [[Gram per litre|µg/dL]]
mcg/dl [[Gram per litre|µg/dl]]
mg/mL [[Gram per litre|mg/mL]]
mg/ml [[Gram per litre|mg/ml]]
ug/dL [[Gram per litre|µg/dL]]
ug/dl [[Gram per litre|µg/dl]]
μg/dL [[Gram per litre|μg/dL]]
μg/dl [[Gram per litre|μg/dl]]
mg.L-1 [[Gram per litre|<abbr title="milligrams per liter">mg/L</abbr>]]
mg/L [[Gram per litre|<abbr title="milligrams per liter">mg/L</abbr>]]
mg.l-1 [[Gram per litre|<abbr title="milligrams per liter">mg/l</abbr>]]
mg/l [[Gram per litre|<abbr title="milligrams per liter">mg/l</abbr>]]
== Fracture toughness ==
MPa.m.5 [[Fracture toughness|MPa⋅m<sup>1/2</sup>]]
kPa.m.5 [[Fracture toughness|kPa⋅m<sup>1/2</sup>]]
Pa.m.5 [[Fracture toughness|Pa⋅m<sup>1/2</sup>]]
== Temperature ==
degC °C ALIAS
degF °F ALIAS
degR °R ALIAS
K [[Kelvin|K]] SI
YK [[Yottakelvin|K]] SI
ZK [[Zettakelvin|K]] SI
EK [[Kelvin|K]] SI
PK [[Petakelvin|K]] SI
TK [[Terakelvin|K]] SI
GK [[Gigakelvin|K]] SI
MK [[Megakelvin|K]] SI
kK [[Kilokelvin|K]] SI
hK [[Hectokelvin|K]] SI
daK [[Decakelvin|K]] SI
dK [[Decikelvin|K]] SI
cK [[Centikelvin|K]] SI
mK [[Millikelvin|K]] SI
µK [[Microkelvin|K]] SI
uK [[Microkelvin|K]] SI
nK [[Nanokelvin|K]] SI
pK [[Picokelvin|K]] SI
fK [[Femtokelvin|K]] SI
aK [[Attokelvin|K]] SI
zK [[Zeptokelvin|K]] SI
yK [[Yoctokelvin|K]] SI
== Electromagnetism ==
Wb [[Weber (unit)|Wb]]
N.A-2 [[Permeability (electromagnetism)|N⋅A<sup>−2</sup>]]
H.m-1 [[Permeability (electromagnetism)|H⋅m<sup>−1</sup>]]
V.m-1 [[Electric field|V⋅m<sup>−1</sup>]]
V/m [[Electric field|V/m]]
C [[Coulomb|C]] SI
YC [[Coulomb|C]] SI
ZC [[Coulomb|C]] SI
EC [[Coulomb|C]] SI
PC [[Coulomb|C]] SI
TC [[Coulomb|C]] SI
GC [[Coulomb|C]] SI
MC [[Coulomb|C]] SI
kC [[Coulomb|C]] SI
hC [[Coulomb|C]] SI
daC [[Coulomb|C]] SI
dC [[Coulomb|C]] SI
cC [[Coulomb|C]] SI
mC [[Coulomb|C]] SI
µC [[Coulomb|C]] SI
uC [[Coulomb|C]] SI
nC [[Coulomb|C]] SI
pC [[Coulomb|C]] SI
fC [[Coulomb|C]] SI
aC [[Coulomb|C]] SI
zC [[Coulomb|C]] SI
yC [[Coulomb|C]] SI
F [[Farad|F]] SI
YF [[Farad|F]] SI
ZF [[Farad|F]] SI
EF [[Farad|F]] SI
PF [[Farad|F]] SI
TF [[Farad|F]] SI
GF [[Farad|F]] SI
MF [[Farad|F]] SI
kF [[Farad|F]] SI
hF [[Farad|F]] SI
daF [[Farad|F]] SI
dF [[Farad|F]] SI
cF [[Farad|F]] SI
mF [[Farad|F]] SI
µF [[Farad|F]] SI
uF [[Farad|F]] SI
nF [[Farad|F]] SI
pF [[Farad|F]] SI
fF [[Farad|F]] SI
aF [[Farad|F]] SI
zF [[Farad|F]] SI
yF [[Farad|F]] SI
H [[Henry (unit)|H]] SI
YH [[Henry (unit)|H]] SI
ZH [[Henry (unit)|H]] SI
EH [[Henry (unit)|H]] SI
PH [[Henry (unit)|H]] SI
TH [[Henry (unit)|H]] SI
GH [[Henry (unit)|H]] SI
MH [[Henry (unit)|H]] SI
kH [[Henry (unit)|H]] SI
hH [[Henry (unit)|H]] SI
daH [[Henry (unit)|H]] SI
dH [[Henry (unit)|H]] SI
cH [[Henry (unit)|H]] SI
mH [[Henry (unit)|H]] SI
µH [[Henry (unit)|H]] SI
uH [[Henry (unit)|H]] SI
nH [[Henry (unit)|H]] SI
pH [[Henry (unit)|H]] SI
fH [[Henry (unit)|H]] SI
aH [[Henry (unit)|H]] SI
zH [[Henry (unit)|H]] SI
yH [[Henry (unit)|H]] SI
A [[Ampere|A]] SI
YA [[Ampere|A]] SI
ZA [[Ampere|A]] SI
EA [[Ampere|A]] SI
PA [[Ampere|A]] SI
TA [[Ampere|A]] SI
GA [[Ampere|A]] SI
MA [[Ampere|A]] SI
kA [[Ampere|A]] SI
hA [[Ampere|A]] SI
daA [[Ampere|A]] SI
dA [[Ampere|A]] SI
cA [[Ampere|A]] SI
mA [[Ampere|A]] SI
µA [[Ampere|A]] SI
uA [[Ampere|A]] SI
nA [[Ampere|A]] SI
pA [[Ampere|A]] SI
fA [[Ampere|A]] SI
aA [[Ampere|A]] SI
zA [[Ampere|A]] SI
yA [[Ampere|A]] SI
V [[Volt|V]] SI
YV [[Volt|V]] SI
ZV [[Volt|V]] SI
EV [[Volt|V]] SI
PV [[Volt|V]] SI
TV [[Volt|V]] SI
GV [[Volt|V]] SI
MV [[Volt|V]] SI
kV [[Volt|V]] SI
hV [[Volt|V]] SI
daV [[Volt|V]] SI
dV [[Volt|V]] SI
cV [[Volt|V]] SI
mV [[Volt|V]] SI
µV [[Volt|V]] SI
uV [[Volt|V]] SI
nV [[Volt|V]] SI
pV [[Volt|V]] SI
fV [[Volt|V]] SI
aV [[Volt|V]] SI
zV [[Volt|V]] SI
yV [[Volt|V]] SI
VA [[Volt-ampere|VA]] SI
YVA [[Volt-ampere|VA]] SI
ZVA [[Volt-ampere|VA]] SI
EVA [[Volt-ampere|VA]] SI
PVA [[Volt-ampere|VA]] SI
TVA [[Volt-ampere|VA]] SI
GVA [[Volt-ampere|VA]] SI
MVA [[Volt-ampere|VA]] SI
kVA [[Volt-ampere|VA]] SI
hVA [[Volt-ampere|VA]] SI
daVA [[Volt-ampere|VA]] SI
dVA [[Volt-ampere|VA]] SI
cVA [[Volt-ampere|VA]] SI
mVA [[Volt-ampere|VA]] SI
µVA [[Volt-ampere|VA]] SI
uVA [[Volt-ampere|VA]] SI
nVA [[Volt-ampere|VA]] SI
pVA [[Volt-ampere|VA]] SI
fVA [[Volt-ampere|VA]] SI
aVA [[Volt-ampere|VA]] SI
zVA [[Volt-ampere|VA]] SI
yVA [[Volt-ampere|VA]] SI
Ω [[Ohm|Ω]] SI
YΩ.m [[Electrical resistivity and conductivity#Definition|YΩ⋅m]] 1e24
ZΩ.m [[Electrical resistivity and conductivity#Definition|ZΩ⋅m]] 1e21
EΩ.m [[Electrical resistivity and conductivity#Definition|EΩ⋅m]] 1e18
PΩ.m [[Electrical resistivity and conductivity#Definition|PΩ⋅m]] 1e15
TΩ.m [[Electrical resistivity and conductivity#Definition|TΩ⋅m]] 1e12
GΩ.m [[Electrical resistivity and conductivity#Definition|GΩ⋅m]] 1e9
MΩ.m [[Electrical resistivity and conductivity#Definition|MΩ⋅m]] 1e6
kΩ.m [[Electrical resistivity and conductivity#Definition|kΩ⋅m]] 1e3
Ω.m [[Electrical resistivity and conductivity#Definition|Ω⋅m]] 1
mΩ.m [[Electrical resistivity and conductivity#Definition|mΩ⋅m]] 1e-3
µΩ.m [[Electrical resistivity and conductivity#Definition|µΩ⋅m]] 1e-6
uΩ.m [[Electrical resistivity and conductivity#Definition|µΩ⋅m]] 1e-6
nΩ.m [[Electrical resistivity and conductivity#Definition|nΩ⋅m]] 1e-9
pΩ.m [[Electrical resistivity and conductivity#Definition|pΩ⋅m]] 1e-12
fΩ.m [[Electrical resistivity and conductivity#Definition|fΩ⋅m]] 1e-15
aΩ.m [[Electrical resistivity and conductivity#Definition|aΩ⋅m]] 1e-18
zΩ.m [[Electrical resistivity and conductivity#Definition|zΩ⋅m]] 1e-21
yΩ.m [[Electrical resistivity and conductivity#Definition|yΩ⋅m]] 1e-24
R [[Rayleigh (unit)|R]] SI
G [[Gauss (unit)|G]] SI
aG [[Attogauss|G]] SI
cG [[Centigauss|G]] SI
daG [[Decagauss|G]] SI
dG [[Decigauss|G]] SI
EG [[Exagauss|G]] SI
fG [[Femtogauss|G]] SI
GG [[Gigagauss|G]] SI
hG [[Hectogauss|G]] SI
kG [[Kilogauss|G]] SI
MG [[Megagauss|G]] SI
mG [[Milligauss|G]] SI
uG [[Microgauss|G]] SI
µG [[Microgauss|G]] SI
nG [[Nanogauss|G]] SI
PG [[Petagauss|G]] SI
pG [[Picogauss|G]] SI
TG [[Teragauss|G]] SI
yG [[Yoctogauss|G]] SI
YG [[Yottagauss|G]] SI
zG [[Zeptogauss|G]] SI
ZG [[Zettagauss|G]] SI
T [[Tesla (unit)|T]] SI
aT [[Attotesla|T]] SI
cT [[Centitesla|T]] SI
daT [[Decatesla|T]] SI
dT [[Decitesla|T]] SI
ET [[Exatesla|T]] SI
fT [[Femtotesla|T]] SI
GT [[Gigatesla|T]] SI
hT [[Hectotesla|T]] SI
kT [[Kilotesla|T]] SI
MT [[Megatesla|T]] SI
mT [[Millitesla|T]] SI
uT [[Microtesla|T]] SI
µT [[Microtesla|T]] SI
nT [[Nanotesla|T]] SI
PT [[Petatesla|T]] SI
pT [[Picotesla|T]] SI
TT [[Teratesla|T]] SI
yT [[Yoctotesla|T]] SI
YT [[Yottatesla|T]] SI
zT [[Zeptotesla|T]] SI
ZT [[Zettatesla|T]] SI
== Astrophysics ==
au [[Astronomical unit|au]]
c [[Speed of light|''c'']]
ly [[Light-year|ly]]
Earth mass [[Earth mass|''M''<sub>🜨</sub>]]
Earth radius [[Earth radius|''R''<sub>🜨</sub>]]
M_Earth [[Earth mass|''M''<sub>🜨</sub>]]
R_Earth [[Earth radius|''R''<sub>🜨</sub>]]
M+ [[Earth mass|''M''<sub>🜨</sub>]]
R+ [[Earth radius|''R''<sub>🜨</sub>]]
Jupiter mass [[Jupiter mass|''M''<sub>J</sub>]]
Jupiter radius [[Jupiter radius|''R''<sub>J</sub>]]
Jy [[Jansky|Jy]]
M_Jupiter [[Jupiter mass|''M''<sub>J</sub>]]
R_Jupiter [[Jupiter radius|''R''<sub>J</sub>]]
Solar mass [[Solar mass|''M''<sub>☉</sub>]]
solar mass [[Solar mass|''M''<sub>☉</sub>]]
M_Solar [[Solar mass|''M''<sub>☉</sub>]]
M_solar [[Solar mass|''M''<sub>☉</sub>]]
R_Solar [[Solar radius|''R''<sub>☉</sub>]]
R_solar [[Solar radius|''R''<sub>☉</sub>]]
Solar radius [[Solar radius|''R''<sub>☉</sub>]]
solar radius [[Solar radius|''R''<sub>☉</sub>]]
Solar luminosity [[Solar luminosity|''L''<sub>☉</sub>]]
solar luminosity [[Solar luminosity|''L''<sub>☉</sub>]]
L_solar [[Solar luminosity|''L''<sub>☉</sub>]]
L_Solar [[Solar luminosity|''L''<sub>☉</sub>]]
Lo [[Solar luminosity|''L''<sub>☉</sub>]]
pc2 [[Parsec|pc<sup>2</sup>]]
pc3 [[Parsec|pc<sup>3</sup>]]
kpc2 [[Parsec#Parsecs and kiloparsecs|kpc<sup>2</sup>]]
kpc3 [[Parsec#Parsecs and kiloparsecs|kpc<sup>3</sup>]]
kpc [[Parsec#Parsecs and kiloparsecs|kpc]]
Mpc2 [[Parsec#Megaparsecs and gigaparsecs|Mpc<sup>2</sup>]]
Mpc3 [[Parsec#Megaparsecs and gigaparsecs|Mpc<sup>3</sup>]]
Mpc [[Parsec#Megaparsecs and gigaparsecs|Mpc]]
Gpc2 [[Parsec#Megaparsecs and gigaparsecs|Gpc<sup>2</sup>]]
Gpc3 [[Parsec#Megaparsecs and gigaparsecs|Gpc<sup>3</sup>]]
Gpc [[Parsec#Megaparsecs and gigaparsecs|Gpc]]
== Nuclear physics and chemistry ==
cm-1 [[Wavenumber|cm<sup>−1</sup>]]
u [[Unified atomic mass unit|u]]
osmol [[Osmole (unit)|osmol]]
Osm [[Osmole (unit)|Osm]]
M [[Molarity|M]]
TM [[Molarity|M]] SI
GM [[Molarity|M]] SI
MM [[Molarity|M]] SI
kM [[Molarity|M]] SI
hM [[Molarity|M]] SI
daM [[Molarity|M]] SI
dM [[Molarity|M]] SI
cM [[Molarity|M]] SI
mM [[Molarity|M]] SI
uM [[Molarity|M]] 1e-6
nM [[Molarity|M]] SI
pM [[Molarity|M]] SI
kg.mol-1 [[Molar mass|kg⋅mol<sup>−1</sup>]]
kg/mol [[Molar mass|kg/mol]]
g.mol-1 [[Molar mass|g⋅mol<sup>−1</sup>]]
g/mol [[Molar mass|g/mol]]
eV/c2 [[Electronvolt#Mass|eV/''c''<sup>2</sup>]]
keV/c2 [[Electronvolt#Mass|keV/''c''<sup>2</sup>]]
MeV/c2 [[Electronvolt#Mass|MeV/''c''<sup>2</sup>]]
GeV/c2 [[Electronvolt#Mass|GeV/''c''<sup>2</sup>]]
TeV/c2 [[Electronvolt#Mass|TeV/''c''<sup>2</sup>]]
eV [[Electronvolt|eV]]
meV [[Electronvolt|meV]]
keV [[Electronvolt|keV]]
MeV [[Electronvolt|MeV]]
GeV [[Electronvolt|GeV]]
TeV [[Electronvolt|TeV]]
mol-1 [[Avogadro constant|mol<sup>−1</sup>]]
J.mol-1 [[Joule per mole|J⋅mol<sup>−1</sup>]]
J/mol [[Joule per mole|J/mol]]
kJ.mol-1 [[Joule per mole|kJ⋅mol<sup>−1</sup>]]
kJ/mol [[Joule per mole|kJ/mol]]
MJ.mol-1 [[Joule per mole|MJ⋅mol<sup>−1</sup>]]
MJ/mol [[Joule per mole|MJ/mol]]
GJ.mol-1 [[Joule per mole|GJ⋅mol<sup>−1</sup>]]
GJ/mol [[Joule per mole|GJ/mol]]
TJ.mol-1 [[Joule per mole|TJ⋅mol<sup>−1</sup>]]
TJ/mol [[Joule per mole|TJ/mol]]
μB [[Bohr magneton|''μ''<sub>B</sub>]]
== Numbers and phrases ==
pp [[Page (paper)|pp]]
ppb [[Parts per billion|ppb]] 1e-9
ppm [[Parts per million|ppm]] 1e-6
billiard [[Orders of magnitude (numbers)#1015|billiard]] 1e15
billion [[1,000,000,000|billion]] 1e9
billionth [[1,000,000,000|billionth]] 1e-9
billionths [[1,000,000,000|billionths]] 1e-9
decilliard [[Orders of magnitude (numbers)#1063|decilliard]] 1e63
decillion [[Orders of magnitude (numbers)#1033|decillion]] 1e33
decillionth [[Orders of magnitude (numbers)#1033|decillionth]] 1e-33
decillionths [[Orders of magnitude (numbers)#1033|decillionths]] 1e-33
milliard [[1,000,000,000|milliard]] 1e9
million [[Million|million]] 1e6
millionth [[Million|millionth]] 1e-6
millionths [[Million|millionths]] 1e-6
nonilliard [[Orders of magnitude (numbers)#1057|nonilliard]] 1e57
nonillion [[Orders of magnitude (numbers)#1030|nonillion]] 1e30
nonillionth [[Orders of magnitude (numbers)#1030|nonillionth]] 1e-30
nonillionths [[Orders of magnitude (numbers)#1030|nonillionths]] 1e-30
octilliard [[Orders of magnitude (numbers)#1051|octilliard]] 1e51
octillion [[Orders of magnitude (numbers)#1027|octillion]] 1e27
octillionth [[Orders of magnitude (numbers)#1027|octillionth]] 1e-27
octillionths [[Orders of magnitude (numbers)#1027|octillionths]] 1e-27
quadrilliard [[Orders of magnitude (numbers)#1027|quadrilliard]] 1e27
quadrillion [[Orders of magnitude (numbers)#1015|quadrillion]] 1e15
quadrillionth [[Orders of magnitude (numbers)#1015|quadrillionth]] 1e-15
quadrillionths [[Orders of magnitude (numbers)#1015|quadrillionths]] 1e-15
quintilliard [[Orders of magnitude (numbers)#1033|quintilliard]] 1e33
quintillion [[Orders of magnitude (numbers)#1018|quintillion]] 1e18
quintillionth [[Orders of magnitude (numbers)#1018|quintillionth]] 1e-18
quintillionths [[Orders of magnitude (numbers)#1018|quintillionths]] 1e-18
septilliard [[Orders of magnitude (numbers)#1045|septilliard]] 1e45
septillion [[Orders of magnitude (numbers)#1024|septillion]] 1e24
septillionth [[Orders of magnitude (numbers)#1024|septillionth]] 1e-24
septillionths [[Orders of magnitude (numbers)#1024|septillionths]] 1e-24
sextilliard [[Orders of magnitude (numbers)#1039|sextilliard]] 1e39
sextillion [[Orders of magnitude (numbers)#1021|sextillion]] 1e21
sextillionth [[Orders of magnitude (numbers)#1021|sextillionth]] 1e-21
sextillionths [[Orders of magnitude (numbers)#1021|sextillionths]] 1e-21
trilliard [[Orders of magnitude (numbers)#1021|trilliard]] 1e21
trillion [[Orders of magnitude (numbers)#1012|trillion]] 1e12
trillionth [[Orders of magnitude (numbers)#1012|trillionth]] 1e-12
trillionths [[Orders of magnitude (numbers)#1012|trillionths]] 1e-12
== Angles ==
% % Percent ANGLE 0.01
percent % Percent ANGLE 0.01
per cent % Percent ANGLE 0.01
‰ ‰ Per mil ANGLE 1e-3
per mil ‰ Per mil ANGLE 1e-3
per mill ‰ Per mil ANGLE 1e-3
per mille ‰ Per mil ANGLE 1e-3
permil ‰ Per mil ANGLE 1e-3
permill ‰ Per mil ANGLE 1e-3
permille ‰ Per mil ANGLE 1e-3
° ° Degree (angle) ANGLE pi/180
deg ° Degree (angle) ANGLE pi/180
degree ° Degree (angle) NOSPACE pi/180 -- for a degree symbol that does not repeat
' ′ Minute of arc ANGLE pi/10800
′ ′ Minute of arc ANGLE pi/10800
arcmin ′ Minute of arc ANGLE pi/10800
arcminute ′ Minute of arc ANGLE pi/10800
" ″ Second of arc ANGLE pi/648000
″ ″ Second of arc ANGLE pi/648000
arcsec ″ Second of arc ANGLE pi/648000
arcsecond ″ Second of arc ANGLE pi/648000
mas [[Milliarcsecond|mas]] pi/648000000
]=]
-- If val has "|long scale=on" the following definitions are used
-- (then, if not found here, the normal definitions are used).
-- Unit code [[Link|Symbol]] Flags/Scale
local builtin_units_long_scale = [=[
== Long scale numbers and phrases ==
billion [[Orders of magnitude (numbers)#1012|billion]] 1e12
billionth [[Orders of magnitude (numbers)#1012|billionth]] 1e-12
billionths [[Orders of magnitude (numbers)#1012|billionths]] 1e-12
decillion [[Orders of magnitude (numbers)#1060|decillion]] 1e60
decillionth [[Orders of magnitude (numbers)#1060|decillionth]] 1e-60
decillionths [[Orders of magnitude (numbers)#1060|decillionths]] 1e-60
nonillion [[Orders of magnitude (numbers)#1054|nonillion]] 1e54
nonillionth [[Orders of magnitude (numbers)#1054|nonillionth]] 1e-54
nonillionths [[Orders of magnitude (numbers)#1054|nonillionths]] 1e-54
octillion [[Orders of magnitude (numbers)#1048|octillion]] 1e48
octillionth [[Orders of magnitude (numbers)#1048|octillionth]] 1e-48
octillionths [[Orders of magnitude (numbers)#1048|octillionths]] 1e-48
quadrillion [[Orders of magnitude (numbers)#1024|quadrillion]] 1e24
quadrillionth [[Orders of magnitude (numbers)#1024|quadrillionth]] 1e-24
quadrillionths [[Orders of magnitude (numbers)#1024|quadrillionths]] 1e-24
quintillion [[Orders of magnitude (numbers)#1030|quintillion]] 1e30
quintillionth [[Orders of magnitude (numbers)#1030|quintillionth]] 1e-30
quintillionths [[Orders of magnitude (numbers)#1030|quintillionths]] 1e-30
septillion [[Orders of magnitude (numbers)#1042|septillion]] 1e42
septillionth [[Orders of magnitude (numbers)#1042|septillionth]] 1e-42
septillionths [[Orders of magnitude (numbers)#1042|septillionths]] 1e-42
sextillion [[Orders of magnitude (numbers)#1036|sextillion]] 1e36
sextillionth [[Orders of magnitude (numbers)#1036|sextillionth]] 1e-36
sextillionths [[Orders of magnitude (numbers)#1036|sextillionths]] 1e-36
trillion [[Orders of magnitude (numbers)#1018|trillion]] 1e18
trillionth [[Orders of magnitude (numbers)#1018|trillionth]] 1e-18
trillionths [[Orders of magnitude (numbers)#1018|trillionths]] 1e-18
]=]
return { builtin_units = builtin_units, builtin_units_long_scale = builtin_units_long_scale }
2307ae0d1410328f2d5ace7ab494855c5cb9c9e9
Module:Convert
828
720
1104
1103
2025-08-22T00:55:50Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Convert a value from one unit of measurement to another.
-- Example: {{convert|123|lb|kg}} --> 123 pounds (56 kg)
-- See [[:en:Template:Convert/Transwiki guide]] if copying to another wiki.
local MINUS = '−' -- Unicode U+2212 MINUS SIGN (UTF-8: e2 88 92)
local abs = math.abs
local floor = math.floor
local format = string.format
local log10 = math.log10
local ustring = mw.ustring
local ulen = ustring.len
local usub = ustring.sub
-- Configuration options to keep magic values in one location.
-- Conversion data and message text are defined in separate modules.
local config, maxsigfig
local numdot -- must be '.' or ',' or a character which works in a regex
local numsep, numsep_remove, numsep_remove2
local data_code, all_units
local text_code
local varname -- can be a code to use variable names that depend on value
local from_en_table -- to translate an output string of en digits to local language
local to_en_table -- to translate an input string of digits in local language to en
-- Use translation_table in convert/text to change the following.
local en_default -- true uses lang=en unless convert has lang=local or local digits
local group_method = 3 -- code for how many digits are in a group
local per_word = 'per' -- for units like "liters per kilometer"
local plural_suffix = 's' -- only other useful value is probably '' to disable plural unit names
local omitsep -- true to omit separator before local symbol/name
-- All units should be defined in the data module. However, to cater for quick changes
-- and experiments, any unknown unit is looked up in an extra data module, if it exists.
-- That module would be transcluded in only a small number of pages, so there should be
-- little server overhead from making changes, and changes should propagate quickly.
local extra_module -- name of module with extra units
local extra_units -- nil or table of extra units from extra_module
-- Some options in the invoking template can set variables used later in the module.
local currency_text -- for a user-defined currency symbol: {{convert|12|$/ha|$=€}} (euro replaces dollar)
local function from_en(text)
-- Input is a string representing a number in en digits with '.' decimal mark,
-- without digit grouping (which is done just after calling this).
-- Return the translation of the string with numdot and digits in local language.
if numdot ~= '.' then
text = text:gsub('%.', numdot)
end
if from_en_table then
text = text:gsub('%d', from_en_table)
end
return text
end
local function to_en(text)
-- Input is a string representing a number in the local language with
-- an optional numdot decimal mark and numsep digit grouping.
-- Return the translation of the string with '.' mark and en digits,
-- and no separators (they have to be removed here to handle cases like
-- numsep = '.' and numdot = ',' with input "1.234.567,8").
if to_en_table then
text = ustring.gsub(text, '%d', to_en_table)
end
if numsep_remove then
text = text:gsub(numsep_remove, '')
end
if numsep_remove2 then
text = text:gsub(numsep_remove2, '')
end
if numdot ~= '.' then
text = text:gsub(numdot, '.')
end
return text
end
local function decimal_mark(text)
-- Return ',' if text probably is using comma for decimal mark, or has no decimal mark.
-- Return '.' if text probably is using dot for decimal mark.
-- Otherwise return nothing (decimal mark not known).
if not text:find('[.,]') then return ',' end
text = text:gsub('^%-', ''):gsub('%+%d+/%d+$', ''):gsub('[Ee]%-?%d+$', '')
local decimal =
text:match('^0?([.,])%d+$') or
text:match('%d([.,])%d?%d?$') or
text:match('%d([.,])%d%d%d%d+$')
if decimal then return decimal end
if text:match('%.%d+%.') then return ',' end
if text:match('%,%d+,') then return '.' end
end
local add_warning, with_separator -- forward declarations
local function to_en_with_check(text, parms)
-- Version of to_en() for a wiki using numdot = ',' and numsep = '.' to check
-- text (an input number as a string) which might have been copied from enwiki.
-- For example, in '1.234' the '.' could be a decimal mark or a group separator.
-- From viwiki.
if to_en_table then
text = ustring.gsub(text, '%d', to_en_table)
end
if decimal_mark(text) == '.' then
local original = text
text = text:gsub(',', '') -- for example, interpret "1,234.5" as an enwiki value
if parms then
add_warning(parms, 0, 'cvt_enwiki_num', original, with_separator({}, text))
end
else
if numsep_remove then
text = text:gsub(numsep_remove, '')
end
if numsep_remove2 then
text = text:gsub(numsep_remove2, '')
end
if numdot ~= '.' then
text = text:gsub(numdot, '.')
end
end
return text
end
local function omit_separator(id)
-- Return true if there should be no separator before id (a unit symbol or name).
-- For zhwiki, there should be no separator if id uses local characters.
-- The following kludge should be a sufficient test.
if omitsep then
if id:sub(1, 2) == '-{' then -- for "-{...}-" content language variant
return true
end
if id:byte() > 127 then
local first = usub(id, 1, 1)
if first ~= 'Å' and first ~= '°' and first ~= 'µ' then
return true
end
end
end
return id:sub(1, 1) == '/' -- no separator before units like "/ha"
end
local spell_module -- name of module that can spell numbers
local speller -- function from that module to handle spelling (set if needed)
local wikidata_module, wikidata_data_module -- names of Wikidata modules
local wikidata_code, wikidata_data -- exported tables from those modules (set if needed)
local function set_config(args)
-- Set configuration options from template #invoke or defaults.
config = args
maxsigfig = config.maxsigfig or 14 -- maximum number of significant figures
local data_module, text_module
local sandbox = config.sandbox and ('/' .. config.sandbox) or ''
data_module = "Module:Convert/data" .. sandbox
text_module = "Module:Convert/text" .. sandbox
extra_module = "Module:Convert/extra" .. sandbox
wikidata_module = "Module:Convert/wikidata" .. sandbox
wikidata_data_module = "Module:Convert/wikidata/data" .. sandbox
spell_module = "Module:ConvertNumeric"
data_code = mw.loadData(data_module)
text_code = mw.loadData(text_module)
all_units = data_code.all_units
local translation = text_code.translation_table
if translation then
numdot = translation.numdot
numsep = translation.numsep
if numdot == ',' and numsep == '.' then
if text_code.all_messages.cvt_enwiki_num then
to_en = to_en_with_check
end
end
if translation.group then
group_method = translation.group
end
if translation.per_word then
per_word = translation.per_word
end
if translation.plural_suffix then
plural_suffix = translation.plural_suffix
end
varname = translation.varname
from_en_table = translation.from_en
local use_workaround = true
if use_workaround then
-- 2013-07-05 workaround bug by making a copy of the required table.
-- mw.ustring.gsub fails with a table (to_en_table) as the replacement,
-- if the table is accessed via mw.loadData.
local source = translation.to_en
if source then
to_en_table = {}
for k, v in pairs(source) do
to_en_table[k] = v
end
end
else
to_en_table = translation.to_en
end
if translation.lang == 'en default' then
en_default = true -- for hiwiki
end
omitsep = translation.omitsep -- for zhwiki
end
numdot = config.numdot or numdot or '.' -- decimal mark before fractional digits
numsep = config.numsep or numsep or ',' -- group separator for numbers
-- numsep should be ',' or '.' or '' or ' ' or a Unicode character.
-- numsep_remove must work in a regex to identify separators to be removed.
if numsep ~= '' then
numsep_remove = (numsep == '.') and '%.' or numsep
end
if numsep ~= ',' and numdot ~= ',' then
numsep_remove2 = ',' -- so numbers copied from enwiki will work
end
end
local function collection()
-- Return a table to hold items.
return {
n = 0,
add = function (self, item)
self.n = self.n + 1
self[self.n] = item
end,
}
end
local function divide(numerator, denominator)
-- Return integers quotient, remainder resulting from dividing the two
-- given numbers, which should be unsigned integers.
local quotient, remainder = floor(numerator / denominator), numerator % denominator
if not (0 <= remainder and remainder < denominator) then
-- Floating point limits may need this, as in {{convert|160.02|Ym|ydftin}}.
remainder = 0
end
return quotient, remainder
end
local function split(text, delimiter)
-- Return a numbered table with fields from splitting text.
-- The delimiter is used in a regex without escaping (for example, '.' would fail).
-- Each field has any leading/trailing whitespace removed.
local t = {}
text = text .. delimiter -- to get last item
for item in text:gmatch('%s*(.-)%s*' .. delimiter) do
table.insert(t, item)
end
return t
end
local function strip(text)
-- If text is a string, return its content with no leading/trailing
-- whitespace. Otherwise return nil (a nil argument gives a nil result).
if type(text) == 'string' then
return text:match("^%s*(.-)%s*$")
end
end
local function table_len(t)
-- Return length (<100) of a numbered table to replace #t which is
-- documented to not work if t is accessed via mw.loadData().
for i = 1, 100 do
if t[i] == nil then
return i - 1
end
end
end
local function wanted_category(catkey, catsort, want_warning)
-- Return message category if it is wanted in current namespace,
-- otherwise return ''.
local cat
local title = mw.title.getCurrentTitle()
if title then
local nsdefault = '0' -- default namespace: '0' = article; '0,10' = article and template
local namespace = title.namespace
for _, v in ipairs(split(config.nscat or nsdefault, ',')) do
if namespace == tonumber(v) then
cat = text_code.all_categories[want_warning and 'warning' or catkey]
if catsort and catsort ~= '' and cat:sub(-2) == ']]' then
cat = cat:sub(1, -3) .. '|' .. mw.text.nowiki(usub(catsort, 1, 20)) .. ']]'
end
break
end
end
end
return cat or ''
end
local function message(parms, mcode, is_warning)
-- Return wikitext for an error message, including category if specified
-- for the message type.
-- mcode = numbered table specifying the message:
-- mcode[1] = 'cvt_xxx' (string used as a key to get message info)
-- mcode[2] = 'parm1' (string to replace '$1' if any in message)
-- mcode[3] = 'parm2' (string to replace '$2' if any in message)
-- mcode[4] = 'parm3' (string to replace '$3' if any in message)
local msg
if type(mcode) == 'table' then
if mcode[1] == 'cvt_no_output' then
-- Some errors should cause convert to output an empty string,
-- for example, for an optional field in an infobox.
return ''
end
msg = text_code.all_messages[mcode[1]]
end
parms.have_problem = true
local function subparm(fmt, ...)
local rep = {}
for i, v in ipairs({...}) do
rep['$' .. i] = v
end
return (fmt:gsub('$%d+', rep))
end
if msg then
local parts = {}
local regex, replace = msg.regex, msg.replace
for i = 1, 3 do
local limit = 40
local s = mcode[i + 1]
if s then
if regex and replace then
s = s:gsub(regex, replace)
limit = nil -- allow long "should be" messages
end
-- Escape user input so it does not break the message.
-- To avoid tags (like {{convert|1<math>23</math>|m}}) breaking
-- the mouseover title, any strip marker starting with char(127) is
-- replaced with '...' (text not needing i18n).
local append
local pos = s:find(string.char(127), 1, true)
if pos then
append = '...'
s = s:sub(1, pos - 1)
end
if limit and ulen(s) > limit then
s = usub(s, 1, limit)
append = '...'
end
s = mw.text.nowiki(s) .. (append or '')
else
s = '?'
end
parts['$' .. i] = s
end
local function ispreview()
-- Return true if a prominent message should be shown.
if parms.test == 'preview' or parms.test == 'nopreview' then
-- For testing, can preview a real message or simulate a preview
-- when running automated tests.
return parms.test == 'preview'
end
local success, revid = pcall(function ()
return (parms.frame):preprocess('{{REVISIONID}}') end)
return success and (revid == '')
end
local want_warning = is_warning and
not config.warnings and -- show unobtrusive warnings if config.warnings not configured
not msg.nowarn -- but use msg settings, not standard warning, if specified
local title = string.gsub(msg[1] or 'Missing message', '$%d+', parts)
local text = want_warning and '*' or msg[2] or 'Missing message'
local cat = wanted_category(msg[3], mcode[2], want_warning)
local anchor = msg[4] or ''
local fmtkey = ispreview() and 'cvt_format_preview' or
(want_warning and 'cvt_format2' or msg.format or 'cvt_format')
local fmt = text_code.all_messages[fmtkey] or 'convert: bug'
return subparm(fmt, title:gsub('"', '"'), text, cat, anchor)
end
return 'Convert internal error: unknown message'
end
function add_warning(parms, level, key, text1, text2) -- for forward declaration above
-- If enabled, add a warning that will be displayed after the convert result.
-- A higher level is more verbose: more kinds of warnings are displayed.
-- To reduce output noise, only the first warning is displayed.
if level <= (tonumber(config.warnings) or 1) then
if parms.warnings == nil then
parms.warnings = message(parms, { key, text1, text2 }, true)
end
end
end
local function spell_number(parms, inout, number, numerator, denominator)
-- Return result of spelling (number, numerator, denominator), or
-- return nil if spelling is not available or not supported for given text.
-- Examples (each value must be a string or nil):
-- number numerator denominator output
-- ------ --------- ----------- -------------------
-- "1.23" nil nil one point two three
-- "1" "2" "3" one and two thirds
-- nil "2" "3" two thirds
if not speller then
local function get_speller(module)
return require(module).spell_number
end
local success
success, speller = pcall(get_speller, spell_module)
if not success or type(speller) ~= 'function' then
add_warning(parms, 1, 'cvt_no_spell', 'spell')
return nil
end
end
local case
if parms.spell_upper == inout then
case = true
parms.spell_upper = nil -- only uppercase first word in a multiple unit
end
local sp = not parms.opt_sp_us
local adj = parms.opt_adjectival
return speller(number, numerator, denominator, case, sp, adj)
end
------------------------------------------------------------------------
-- BEGIN: Code required only for built-in units.
-- LATER: If need much more code, move to another module to simplify this module.
local function speed_of_sound(altitude)
-- This is for the Mach built-in unit of speed.
-- Return speed of sound in metres per second at given altitude in feet.
-- If no altitude given, use default (zero altitude = sea level).
-- Table gives speed of sound in miles per hour at various altitudes:
-- altitude = -17,499 to 402,499 feet
-- mach_table[a + 4] = s where
-- a = (altitude / 5000) rounded to nearest integer (-3 to 80)
-- s = speed of sound (mph) at that altitude
-- LATER: Should calculate result from an interpolation between the next
-- lower and higher altitudes in table, rather than rounding to nearest.
-- From: http://www.aerospaceweb.org/question/atmosphere/q0112.shtml
local mach_table = { -- a =
799.5, 787.0, 774.2, 761.207051, -- -3 to 0
748.0, 734.6, 721.0, 707.0, 692.8, 678.3, 663.5, 660.1, 660.1, 660.1, -- 1 to 10
660.1, 660.1, 660.1, 662.0, 664.3, 666.5, 668.9, 671.1, 673.4, 675.6, -- 11 to 20
677.9, 683.7, 689.9, 696.0, 702.1, 708.1, 714.0, 719.9, 725.8, 731.6, -- 21 to 30
737.3, 737.7, 737.7, 736.2, 730.5, 724.6, 718.8, 712.9, 707.0, 701.0, -- 31 to 40
695.0, 688.9, 682.8, 676.6, 670.4, 664.1, 657.8, 652.9, 648.3, 643.7, -- 41 to 50
639.1, 634.4, 629.6, 624.8, 620.0, 615.2, 613.2, 613.2, 613.2, 613.5, -- 51 to 60
614.4, 615.3, 616.7, 619.8, 623.4, 629.7, 635.0, 641.1, 650.6, 660.0, -- 61 to 70
672.5, 674.3, 676.1, 677.9, 679.7, 681.5, 683.3, 685.1, 686.8, 688.6, -- 71 to 80
}
altitude = altitude or 0
local a = (altitude < 0) and -altitude or altitude
a = floor(a / 5000 + 0.5)
if altitude < 0 then
a = -a
end
if a < -3 then
a = -3
elseif a > 80 then
a = 80
end
return mach_table[a + 4] * 0.44704 -- mph converted to m/s
end
-- END: Code required only for built-in units.
------------------------------------------------------------------------
local function add_style(parms, class)
-- Add selected template style to parms if not already present.
parms.templatestyles = parms.templatestyles or {}
if not parms.templatestyles[class] then
parms.templatestyles[class] = parms.frame:extensionTag({
name = 'templatestyles', args = { src = text_code.titles[class] }
})
end
end
local function get_styles(parms)
-- Return string of required template styles, empty if none.
if parms.templatestyles then
local t = {}
for _, v in pairs(parms.templatestyles) do
table.insert(t, v)
end
return table.concat(t)
end
return ''
end
local function get_range(word)
-- Return a range (string or table) corresponding to word (like "to"),
-- or return nil if not a range word.
local ranges = text_code.ranges
return ranges.types[word] or ranges.types[ranges.aliases[word]]
end
local function check_mismatch(unit1, unit2)
-- If unit1 cannot be converted to unit2, return an error message table.
-- This allows conversion between units of the same type, and between
-- Nm (normally torque) and ftlb (energy), as in gun-related articles.
-- This works because Nm is the base unit (scale = 1) for both the
-- primary type (torque), and the alternate type (energy, where Nm = J).
-- A match occurs if the primary types are the same, or if unit1 matches
-- the alternate type of unit2, and vice versa. That provides a whitelist
-- of which conversions are permitted between normally incompatible types.
if unit1.utype == unit2.utype or
(unit1.utype == unit2.alttype and unit1.alttype == unit2.utype) then
return nil
end
return { 'cvt_mismatch', unit1.utype, unit2.utype }
end
local function override_from(out_table, in_table, fields)
-- Copy the specified fields from in_table to out_table, but do not
-- copy nil fields (keep any corresponding field in out_table).
for _, field in ipairs(fields) do
if in_table[field] then
out_table[field] = in_table[field]
end
end
end
local function shallow_copy(t)
-- Return a shallow copy of table t.
-- Do not need the features and overhead of the Scribunto mw.clone().
local result = {}
for k, v in pairs(t) do
result[k] = v
end
return result
end
local unit_mt = {
-- Metatable to get missing values for a unit that does not accept SI prefixes.
-- Warning: The boolean value 'false' is returned for any missing field
-- so __index is not called twice for the same field in a given unit.
__index = function (self, key)
local value
if key == 'name1' or key == 'sym_us' then
value = self.symbol
elseif key == 'name2' then
value = self.name1 .. plural_suffix
elseif key == 'name1_us' then
value = self.name1
if not rawget(self, 'name2_us') then
-- If name1_us is 'foot', do not make name2_us by appending plural_suffix.
self.name2_us = self.name2
end
elseif key == 'name2_us' then
local raw1_us = rawget(self, 'name1_us')
if raw1_us then
value = raw1_us .. plural_suffix
else
value = self.name2
end
elseif key == 'link' then
value = self.name1
else
value = false
end
rawset(self, key, value)
return value
end
}
local function prefixed_name(unit, name, index)
-- Return unit name with SI prefix inserted at correct position.
-- index = 1 (name1), 2 (name2), 3 (name1_us), 4 (name2_us).
-- The position is a byte (not character) index, so use Lua's sub().
local pos = rawget(unit, 'prefix_position')
if type(pos) == 'string' then
pos = tonumber(split(pos, ',')[index])
end
if pos then
return name:sub(1, pos - 1) .. unit.si_name .. name:sub(pos)
end
return unit.si_name .. name
end
local unit_prefixed_mt = {
-- Metatable to get missing values for a unit that accepts SI prefixes.
-- Before use, fields si_name, si_prefix must be defined.
-- The unit must define _symbol, _name1 and
-- may define _sym_us, _name1_us, _name2_us
-- (_sym_us, _name2_us may be defined for a language using sp=us
-- to refer to a variant unrelated to U.S. units).
__index = function (self, key)
local value
if key == 'symbol' then
value = self.si_prefix .. self._symbol
if value == 'l' then value = 'L' end
elseif key == 'sym_us' then
value = rawget(self, '_sym_us')
if value then
value = self.si_prefix .. value
else
value = self.symbol
end
elseif key == 'name1' then
value = prefixed_name(self, self._name1, 1)
elseif key == 'name2' then
value = rawget(self, '_name2')
if value then
value = prefixed_name(self, value, 2)
else
value = self.name1 .. plural_suffix
end
elseif key == 'name1_us' then
value = rawget(self, '_name1_us')
if value then
value = prefixed_name(self, value, 3)
else
value = self.name1
end
elseif key == 'name2_us' then
value = rawget(self, '_name2_us')
if value then
value = prefixed_name(self, value, 4)
elseif rawget(self, '_name1_us') then
value = self.name1_us .. plural_suffix
else
value = self.name2
end
elseif key == 'link' then
value = self.name1
else
value = false
end
rawset(self, key, value)
return value
end
}
local unit_per_mt = {
-- Metatable to get values for a per unit of form "x/y".
-- This is never called to determine a unit name or link because per units
-- are handled as a special case.
-- Similarly, the default output is handled elsewhere, and for a symbol
-- this is only called from get_default() for default_exceptions.
__index = function (self, key)
local value
if key == 'symbol' then
local per = self.per
local unit1, unit2 = per[1], per[2]
if unit1 then
value = unit1[key] .. '/' .. unit2[key]
else
value = '/' .. unit2[key]
end
elseif key == 'sym_us' then
value = self.symbol
elseif key == 'scale' then
local per = self.per
local unit1, unit2 = per[1], per[2]
value = (unit1 and unit1.scale or 1) * self.scalemultiplier / unit2.scale
else
value = false
end
rawset(self, key, value)
return value
end
}
local function make_per(unitcode, unit_table, ulookup)
-- Return true, t where t is a per unit with unit codes expanded to unit tables,
-- or return false, t where t is an error message table.
local result = {
unitcode = unitcode,
utype = unit_table.utype,
per = {}
}
override_from(result, unit_table, { 'invert', 'iscomplex', 'default', 'link', 'symbol', 'symlink' })
result.symbol_raw = (result.symbol or false) -- to distinguish between a defined exception and a metatable calculation
local prefix
for i, v in ipairs(unit_table.per) do
if i == 1 and v == '' then
-- First unit symbol can be empty; that gives a nil first unit table.
elseif i == 1 and text_code.currency[v] then
prefix = currency_text or v
else
local success, t = ulookup(v)
if not success then return false, t end
result.per[i] = t
end
end
local multiplier = unit_table.multiplier
if not result.utype then
-- Creating an automatic per unit.
local unit1 = result.per[1]
local utype = (unit1 and unit1.utype or prefix or '') .. '/' .. result.per[2].utype
local t = data_code.per_unit_fixups[utype]
if t then
if type(t) == 'table' then
utype = t.utype or utype
result.link = result.link or t.link
multiplier = multiplier or t.multiplier
else
utype = t
end
end
result.utype = utype
end
result.scalemultiplier = multiplier or 1
result.vprefix = prefix or false -- set to non-nil to avoid calling __index
return true, setmetatable(result, unit_per_mt)
end
local function lookup(parms, unitcode, what, utable, fails, depth)
-- Return true, t where t is a copy of the unit's converter table,
-- or return false, t where t is an error message table.
-- Parameter 'what' determines whether combination units are accepted:
-- 'no_combination' : single unit only
-- 'any_combination' : single unit or combination or output multiple
-- 'only_multiple' : single unit or output multiple only
-- Parameter unitcode is a symbol (like 'g'), with an optional SI prefix (like 'kg').
-- If, for example, 'kg' is in this table, that entry is used;
-- otherwise the prefix ('k') is applied to the base unit ('g').
-- If unitcode is a known combination code (and if allowed by what),
-- a table of output multiple unit tables is included in the result.
-- For compatibility with the old template, an underscore in a unitcode is
-- replaced with a space so usage like {{convert|350|board_feet}} works.
-- Wikignomes may also put two spaces or " " in combinations, so
-- replace underscore, " ", and multiple spaces with a single space.
utable = utable or parms.unittable or all_units
fails = fails or {}
depth = depth and depth + 1 or 1
if depth > 9 then
-- There are ways to mistakenly define units which result in infinite
-- recursion when lookup() is called. That gives a long delay and very
-- confusing error messages, so the depth parameter is used as a guard.
return false, { 'cvt_lookup', unitcode }
end
if unitcode == nil or unitcode == '' then
return false, { 'cvt_no_unit' }
end
unitcode = unitcode:gsub('_', ' '):gsub(' ', ' '):gsub(' +', ' ')
local function call_make_per(t)
return make_per(unitcode, t,
function (ucode) return lookup(parms, ucode, 'no_combination', utable, fails, depth) end
)
end
local t = utable[unitcode]
if t then
if t.shouldbe then
return false, { 'cvt_should_be', t.shouldbe }
end
if t.sp_us then
parms.opt_sp_us = true
end
local target = t.target -- nil, or unitcode is an alias for this target
if target then
local success, result = lookup(parms, target, what, utable, fails, depth)
if not success then return false, result end
override_from(result, t, { 'customary', 'default', 'link', 'symbol', 'symlink', 'usename' })
local multiplier = t.multiplier
if multiplier then
result.multiplier = tostring(multiplier)
result.scale = result.scale * multiplier
end
return true, result
end
if t.per then
return call_make_per(t)
end
local combo = t.combination -- nil or a table of unitcodes
if combo then
local multiple = t.multiple
if what == 'no_combination' or (what == 'only_multiple' and not multiple) then
return false, { 'cvt_bad_unit', unitcode }
end
-- Recursively create a combination table containing the
-- converter table of each unitcode.
local result = { utype = t.utype, multiple = multiple, combination = {} }
local cvt = result.combination
for i, v in ipairs(combo) do
local success, t = lookup(parms, v, multiple and 'no_combination' or 'only_multiple', utable, fails, depth)
if not success then return false, t end
cvt[i] = t
end
return true, result
end
local result = shallow_copy(t)
result.unitcode = unitcode
if result.prefixes then
result.si_name = ''
result.si_prefix = ''
return true, setmetatable(result, unit_prefixed_mt)
end
return true, setmetatable(result, unit_mt)
end
local SIprefixes = text_code.SIprefixes
for plen = SIprefixes[1] or 2, 1, -1 do
-- Look for an SI prefix; should never occur with an alias.
-- Check for longer prefix first ('dam' is decametre).
-- SIprefixes[1] = prefix maximum #characters (as seen by mw.ustring.sub).
local prefix = usub(unitcode, 1, plen)
local si = SIprefixes[prefix]
if si then
local t = utable[usub(unitcode, plen+1)]
if t and t.prefixes then
local result = shallow_copy(t)
result.unitcode = unitcode
result.si_name = parms.opt_sp_us and si.name_us or si.name
result.si_prefix = si.prefix or prefix
result.scale = t.scale * 10 ^ (si.exponent * t.prefixes)
return true, setmetatable(result, unit_prefixed_mt)
end
end
end
-- Accept user-defined combinations like "acre+m2+ha" or "acre m2 ha" for output.
-- If '+' is used, each unit code can include a space, and any error is fatal.
-- If ' ' is used and if each space-separated word is a unit code, it is a combo,
-- but errors are not fatal so the unit code can be looked up as an extra unit.
local err_is_fatal
local combo = collection()
if unitcode:find('+', 1, true) then
err_is_fatal = true
for item in (unitcode .. '+'):gmatch('%s*(.-)%s*%+') do
if item ~= '' then
combo:add(item)
end
end
elseif unitcode:find('%s') then
for item in unitcode:gmatch('%S+') do
combo:add(item)
end
end
if combo.n > 1 then
local function lookup_combo()
if what == 'no_combination' or what == 'only_multiple' then
return false, { 'cvt_bad_unit', unitcode }
end
local result = { combination = {} }
local cvt = result.combination
for i, v in ipairs(combo) do
local success, t = lookup(parms, v, 'only_multiple', utable, fails, depth)
if not success then return false, t end
if i == 1 then
result.utype = t.utype
else
local mismatch = check_mismatch(result, t)
if mismatch then
return false, mismatch
end
end
cvt[i] = t
end
return true, result
end
local success, result = lookup_combo()
if success or err_is_fatal then
return success, result
end
end
-- Accept any unit with an engineering notation prefix like "e6cuft"
-- (million cubic feet), but not chained prefixes like "e3e6cuft",
-- and not if the unit is a combination or multiple,
-- and not if the unit has an offset or is a built-in.
-- Only en digits are accepted.
local e, exponent, baseunit = unitcode:match('^([Ee])(%d+)(.*)')
if exponent then
local engscale = text_code.eng_scales[exponent]
if engscale then
local success, result = lookup(parms, baseunit, 'no_combination', utable, fails, depth)
if success and not (result.offset or result.builtin or result.engscale) then
if e == 'E' then
result.this_number_word = true
unitcode = 'e' .. unitcode:sub(2)
end
result.unitcode = unitcode -- 'e6cuft' not 'cuft'
result.defkey = unitcode -- key to lookup default exception
result.engscale = engscale
result.scale = result.scale * 10 ^ tonumber(exponent)
return true, result
end
end
end
-- Look for x/y; split on right-most slash to get scale correct (x/y/z is x/y per z).
local top, bottom = unitcode:match('^(.-)/([^/]+)$')
if top and not unitcode:find('e%d') then
-- If valid, create an automatic per unit for an "x/y" unit code.
-- The unitcode must not include extraneous spaces.
-- Engineering notation (apart from at start and which has been stripped before here),
-- is not supported so do not make a per unit if find text like 'e3' in unitcode.
local success, result = call_make_per({ per = {top, bottom} })
if success then
return true, result
end
end
if not parms.opt_ignore_error and not get_range(unitcode) then
-- Want the "what links here" list for the extra_module to show only cases
-- where an extra unit is used, so do not require it if invoked from {{val}}
-- or if looking up a range word which cannot be a unit.
if not extra_units then
local success, extra = pcall(function () return require(extra_module).extra_units end)
if success and type(extra) == 'table' then
extra_units = extra
end
end
if extra_units then
-- A unit in one data table might refer to a unit in the other table, so
-- switch between them, relying on fails or depth to terminate loops.
if not fails[unitcode] then
fails[unitcode] = true
local other = (utable == all_units) and extra_units or all_units
local success, result = lookup(parms, unitcode, what, other, fails, depth)
if success then
return true, result
end
end
end
end
if to_en_table then
-- At fawiki it is common to translate all digits so a unit like "km2" becomes "km۲".
local en_code = ustring.gsub(unitcode, '%d', to_en_table)
if en_code ~= unitcode then
return lookup(parms, en_code, what, utable, fails, depth)
end
end
return false, { 'cvt_unknown', unitcode }
end
local function valid_number(num)
-- Return true if num is a valid number.
-- In Scribunto (different from some standard Lua), when expressed as a string,
-- overflow or other problems are indicated with text like "inf" or "nan"
-- which are regarded as invalid here (each contains "n").
if type(num) == 'number' and tostring(num):find('n', 1, true) == nil then
return true
end
end
local function hyphenated(name, parts)
-- Return a hyphenated form of given name (for adjectival usage).
-- The name may be linked and the target of the link must not be changed.
-- Hypothetical examples:
-- [[long ton|ton]] → [[long ton|ton]] (no change)
-- [[tonne|long ton]] → [[tonne|long-ton]]
-- [[metric ton|long ton]] → [[metric ton|long-ton]]
-- [[long ton]] → [[long ton|long-ton]]
-- Input can also have multiple links in a single name like:
-- [[United States customary units|U.S.]] [[US gallon|gallon]]
-- [[mile]]s per [[United States customary units|U.S.]] [[quart]]
-- [[long ton]]s per [[short ton]]
-- Assume that links cannot be nested (never like "[[abc[[def]]ghi]]").
-- This uses a simple and efficient procedure that works for most cases.
-- Some units (if used) would require more, and can later think about
-- adding a method to handle exceptions.
-- The procedure is to replace each space with a hyphen, but
-- not a space after ')' [for "(pre-1954 US) nautical mile"], and
-- not spaces immediately before '(' or in '(...)' [for cases like
-- "British thermal unit (ISO)" and "Calorie (International Steam Table)"].
if name:find(' ', 1, true) then
if parts then
local pos
if name:sub(1, 1) == '(' then
pos = name:find(')', 1, true)
if pos then
return name:sub(1, pos+1) .. name:sub(pos+2):gsub(' ', '-')
end
elseif name:sub(-1) == ')' then
pos = name:find('(', 1, true)
if pos then
return name:sub(1, pos-2):gsub(' ', '-') .. name:sub(pos-1)
end
end
return name:gsub(' ', '-')
end
parts = collection()
for before, item, after in name:gmatch('([^[]*)(%[%[[^[]*%]%])([^[]*)') do
if item:find(' ', 1, true) then
local prefix
local plen = item:find('|', 1, true)
if plen then
prefix = item:sub(1, plen)
item = item:sub(plen + 1, -3)
else
prefix = item:sub(1, -3) .. '|'
item = item:sub(3, -3)
end
item = prefix .. hyphenated(item, parts) .. ']]'
end
parts:add(before:gsub(' ', '-') .. item .. after:gsub(' ', '-'))
end
if parts.n == 0 then
-- No link like "[[...]]" was found in the original name.
parts:add(hyphenated(name, parts))
end
return table.concat(parts)
end
return name
end
local function hyphenated_maybe(parms, want_name, sep, id, inout)
-- Return s, f where
-- s = id, possibly modified
-- f = true if hyphenated
-- Possible modifications: hyphenate; prepend '-'; append mid text.
if id == nil or id == '' then
return ''
end
local mid = (inout == (parms.opt_flip and 'out' or 'in')) and parms.mid or ''
if want_name then
if parms.opt_adjectival then
return '-' .. hyphenated(id) .. mid, true
end
if parms.opt_add_s and id:sub(-1) ~= 's' then
id = id .. 's' -- for nowiki
end
end
return sep .. id .. mid
end
local function use_minus(text)
-- Return text with Unicode minus instead of '-', if present.
if text:sub(1, 1) == '-' then
return MINUS .. text:sub(2)
end
return text
end
local function digit_groups(parms, text, method)
-- Return a numbered table of groups of digits (left-to-right, in local language).
-- Parameter method is a number or nil:
-- 3 for 3-digit grouping (default), or
-- 2 for 3-then-2 grouping (only for digits before decimal mark).
local len_right
local len_left = text:find('.', 1, true)
if len_left then
len_right = #text - len_left
len_left = len_left - 1
else
len_left = #text
end
local twos = method == 2 and len_left > 5
local groups = collection()
local run = len_left
local n
if run < 4 or (run == 4 and parms.opt_comma5) then
if parms.opt_gaps then
n = run
else
n = #text
end
elseif twos then
n = run % 2 == 0 and 1 or 2
else
n = run % 3 == 0 and 3 or run % 3
end
while run > 0 do
groups:add(n)
run = run - n
n = (twos and run > 3) and 2 or 3
end
if len_right then
if groups.n == 0 then
groups:add(0)
end
if parms.opt_gaps and len_right > 3 then
local want4 = not parms.opt_gaps3 -- true gives no gap before trailing single digit
local isfirst = true
run = len_right
while run > 0 do
n = (want4 and run == 4) and 4 or (run > 3 and 3 or run)
if isfirst then
isfirst = false
groups[groups.n] = groups[groups.n] + 1 + n
else
groups:add(n)
end
run = run - n
end
else
groups[groups.n] = groups[groups.n] + 1 + len_right
end
end
local pos = 1
for i, length in ipairs(groups) do
groups[i] = from_en(text:sub(pos, pos + length - 1))
pos = pos + length
end
return groups
end
function with_separator(parms, text) -- for forward declaration above
-- Input text is a number in en digits with optional '.' decimal mark.
-- Return an equivalent, formatted for display:
-- with a custom decimal mark instead of '.', if wanted
-- with thousand separators inserted, if wanted
-- digits in local language
-- The given text is like '123' or '123.' or '12345.6789'.
-- The text has no sign (caller inserts that later, if necessary).
-- When using gaps, they are inserted before and after the decimal mark.
-- Separators are inserted only before the decimal mark.
-- A trailing dot (as in '123.') is removed because their use appears to
-- be accidental, and such a number should be shown as '123' or '123.0'.
-- It is useful for convert to suppress the dot so, for example, '4000.'
-- is a simple way of indicating that all the digits are significant.
if text:sub(-1) == '.' then
text = text:sub(1, -2)
end
if #text < 4 or parms.opt_nocomma or numsep == '' then
return from_en(text)
end
local groups = digit_groups(parms, text, group_method)
if parms.opt_gaps then
if groups.n <= 1 then
return groups[1] or ''
end
local nowrap = '<span style="white-space: nowrap">'
local gap = '<span style="margin-left: 0.25em">'
local close = '</span>'
return nowrap .. groups[1] .. gap .. table.concat(groups, close .. gap, 2, groups.n) .. close .. close
end
return table.concat(groups, numsep)
end
-- An input value like 1.23e12 is displayed using scientific notation (1.23×10¹²).
-- That also makes the output use scientific notation, except for small values.
-- In addition, very small or very large output values use scientific notation.
-- Use format(fmtpower, significand, '10', exponent) where each argument is a string.
local fmtpower = '%s<span style="margin:0 .15em 0 .25em">×</span>%s<sup>%s</sup>'
local function with_exponent(parms, show, exponent)
-- Return wikitext to display the implied value in scientific notation.
-- Input uses en digits; output uses digits in local language.
return format(fmtpower, with_separator(parms, show), from_en('10'), use_minus(from_en(tostring(exponent))))
end
local function make_sigfig(value, sigfig)
-- Return show, exponent that are equivalent to the result of
-- converting the number 'value' (where value >= 0) to a string,
-- rounded to 'sigfig' significant figures.
-- The returned items are:
-- show: a string of digits; no sign and no dot;
-- there is an implied dot before show.
-- exponent: a number (an integer) to shift the implied dot.
-- Resulting value = tonumber('.' .. show) * 10^exponent.
-- Examples:
-- make_sigfig(23.456, 3) returns '235', 2 (.235 * 10^2).
-- make_sigfig(0.0023456, 3) returns '235', -2 (.235 * 10^-2).
-- make_sigfig(0, 3) returns '000', 1 (.000 * 10^1).
if sigfig <= 0 then
sigfig = 1
elseif sigfig > maxsigfig then
sigfig = maxsigfig
end
if value == 0 then
return string.rep('0', sigfig), 1
end
local exp, fracpart = math.modf(log10(value))
if fracpart >= 0 then
fracpart = fracpart - 1
exp = exp + 1
end
local digits = format('%.0f', 10^(fracpart + sigfig))
if #digits > sigfig then
-- Overflow (for sigfig=3: like 0.9999 rounding to "1000"; need "100").
digits = digits:sub(1, sigfig)
exp = exp + 1
end
assert(#digits == sigfig, 'Bug: rounded number has wrong length')
return digits, exp
end
-- Fraction output format.
local fracfmt = {
{ -- Like {{frac}} (fraction slash).
'<span class="frac">{SIGN}<span class="num">{NUM}</span>⁄<span class="den">{DEN}</span></span>', -- 1/2
'<span class="frac">{SIGN}{WHOLE}<span class="sr-only">+</span><span class="num">{NUM}</span>⁄<span class="den">{DEN}</span></span>', -- 1+2/3
style = 'frac',
},
{ -- Like {{sfrac}} (stacked fraction, that is, horizontal bar).
'<span class="sfrac tion">{SIGN}<span class="num">{NUM}</span><span class="sr-only">/</span><span class="den">{DEN}</span></span>', -- 1//2
'<span class="sfrac">{SIGN}{WHOLE}<span class="sr-only">+</span><span class="tion"><span class="num">{NUM}</span><span class="sr-only">/</span><span class="den">{DEN}</span></span></span>', -- 1+2//3
style = 'sfrac',
},
}
local function format_fraction(parms, inout, negative, wholestr, numstr, denstr, do_spell, style)
-- Return wikitext for a fraction, possibly spelled.
-- Inputs use en digits and have no sign; output uses digits in local language.
local wikitext
if not style then
style = parms.opt_fraction_horizontal and 2 or 1
end
if wholestr == '' then
wholestr = nil
end
local substitute = {
SIGN = negative and MINUS or '',
WHOLE = wholestr and with_separator(parms, wholestr),
NUM = from_en(numstr),
DEN = from_en(denstr),
}
wikitext = fracfmt[style][wholestr and 2 or 1]:gsub('{(%u+)}', substitute)
if do_spell then
if negative then
if wholestr then
wholestr = '-' .. wholestr
else
numstr = '-' .. numstr
end
end
local s = spell_number(parms, inout, wholestr, numstr, denstr)
if s then
return s
end
end
add_style(parms, fracfmt[style].style)
return wikitext
end
local function format_number(parms, show, exponent, isnegative)
-- Parameter show is a string or a table containing strings.
-- Each string is a formatted number in en digits and optional '.' decimal mark.
-- A table represents a fraction: integer, numerator, denominator;
-- if a table is given, exponent must be nil.
-- Return t where t is a table with fields:
-- show = wikitext formatted to display implied value
-- (digits in local language)
-- is_scientific = true if show uses scientific notation
-- clean = unformatted show (possibly adjusted and with inserted '.')
-- (en digits)
-- sign = '' or MINUS
-- exponent = exponent (possibly adjusted)
-- The clean and exponent fields can be used to calculate the
-- rounded absolute value, if needed.
--
-- The value implied by the arguments is found from:
-- exponent is nil; and
-- show is a string of digits (no sign), with an optional dot;
-- show = '123.4' is value 123.4, '1234' is value 1234.0;
-- or:
-- exponent is an integer indicating where dot should be;
-- show is a string of digits (no sign and no dot);
-- there is an implied dot before show;
-- show does not start with '0';
-- show = '1234', exponent = 3 is value 0.1234*10^3 = 123.4.
--
-- The formatted result:
-- * Is for an output value and is spelled if wanted and possible.
-- * Includes a Unicode minus if isnegative and not spelled.
-- * Uses a custom decimal mark, if wanted.
-- * Has digits grouped where necessary, if wanted.
-- * Uses scientific notation if requested, or for very small or large values
-- (which forces result to not be spelled).
-- * Has no more than maxsigfig significant digits
-- (same as old template and {{#expr}}).
local xhi, xlo -- these control when scientific notation (exponent) is used
if parms.opt_scientific then
xhi, xlo = 4, 2 -- default for output if input uses e-notation
elseif parms.opt_scientific_always then
xhi, xlo = 0, 0 -- always use scientific notation (experimental)
else
xhi, xlo = 10, 4 -- default
end
local sign = isnegative and MINUS or ''
local maxlen = maxsigfig
local tfrac
if type(show) == 'table' then
tfrac = show
show = tfrac.wholestr
assert(exponent == nil, 'Bug: exponent given with fraction')
end
if not tfrac and not exponent then
local integer, dot, decimals = show:match('^(%d*)(%.?)(.*)')
if integer == '0' or integer == '' then
local zeros, figs = decimals:match('^(0*)([^0]?.*)')
if #figs == 0 then
if #zeros > maxlen then
show = '0.' .. zeros:sub(1, maxlen)
end
elseif #zeros >= xlo then
show = figs
exponent = -#zeros
elseif #figs > maxlen then
show = '0.' .. zeros .. figs:sub(1, maxlen)
end
elseif #integer >= xhi then
show = integer .. decimals
exponent = #integer
else
maxlen = maxlen + #dot
if #show > maxlen then
show = show:sub(1, maxlen)
end
end
end
if exponent then
local function zeros(n)
return string.rep('0', n)
end
if #show > maxlen then
show = show:sub(1, maxlen)
end
if exponent > xhi or exponent <= -xlo or (exponent == xhi and show ~= '1' .. zeros(xhi - 1)) then
-- When xhi, xlo = 10, 4 (the default), scientific notation is used if the
-- rounded value satisfies: value >= 1e9 or value < 1e-4 (1e9 = 0.1e10),
-- except if show is '1000000000' (1e9), for example:
-- {{convert|1000000000|m|m|sigfig=10}} → 1,000,000,000 metres (1,000,000,000 m)
local significand
if #show > 1 then
significand = show:sub(1, 1) .. '.' .. show:sub(2)
else
significand = show
end
return {
clean = '.' .. show,
exponent = exponent,
sign = sign,
show = sign .. with_exponent(parms, significand, exponent-1),
is_scientific = true,
}
end
if exponent >= #show then
show = show .. zeros(exponent - #show) -- result has no dot
elseif exponent <= 0 then
show = '0.' .. zeros(-exponent) .. show
else
show = show:sub(1, exponent) .. '.' .. show:sub(exponent+1)
end
end
local formatted_show
if tfrac then
show = tostring(tfrac.value) -- to set clean in returned table
formatted_show = format_fraction(parms, 'out', isnegative, tfrac.wholestr, tfrac.numstr, tfrac.denstr, parms.opt_spell_out)
else
if isnegative and show:match('^0.?0*$') then
sign = '' -- don't show minus if result is negative but rounds to zero
end
formatted_show = sign .. with_separator(parms, show)
if parms.opt_spell_out then
formatted_show = spell_number(parms, 'out', sign .. show) or formatted_show
end
end
return {
clean = show,
sign = sign,
show = formatted_show,
is_scientific = false, -- to avoid calling __index
}
end
local function extract_fraction(parms, text, negative)
-- If text represents a fraction, return
-- value, altvalue, show, denominator
-- where
-- value is a number (value of the fraction in argument text)
-- altvalue is an alternate interpretation of any fraction for the hands
-- unit where "12.1+3/4" means 12 hands 1.75 inches
-- show is a string (formatted text for display of an input value,
-- and is spelled if wanted and possible)
-- denominator is value of the denominator in the fraction
-- Otherwise, return nil.
-- Input uses en digits and '.' decimal mark (input has been translated).
-- Output uses digits in local language and local decimal mark, if any.
------------------------------------------------------------------------
-- Originally this function accepted x+y/z where x, y, z were any valid
-- numbers, possibly with a sign. For example '1.23e+2+1.2/2.4' = 123.5,
-- and '2-3/8' = 1.625. However, such usages were found to be errors or
-- misunderstandings, so since August 2014 the following restrictions apply:
-- x (if present) is an integer or has a single digit after decimal mark
-- y and z are unsigned integers
-- e-notation is not accepted
-- The overall number can start with '+' or '-' (so '12+3/4' and '+12+3/4'
-- and '-12-3/4' are valid).
-- Any leading negative sign is removed by the caller, so only inputs
-- like the following are accepted here (may have whitespace):
-- negative = false false true (there was a leading '-')
-- text = '2/3' '+2/3' '2/3'
-- text = '1+2/3' '+1+2/3' '1-2/3'
-- text = '12.3+1/2' '+12.3+1/2' '12.3-1/2'
-- Values like '12.3+1/2' are accepted, but are intended only for use
-- with the hands unit (not worth adding code to enforce that).
------------------------------------------------------------------------
local leading_plus, prefix, numstr, slashes, denstr =
text:match('^%s*(%+?)%s*(.-)%s*(%d+)%s*(/+)%s*(%d+)%s*$')
if not leading_plus then
-- Accept a single U+2044 fraction slash because that may be pasted.
leading_plus, prefix, numstr, denstr =
text:match('^%s*(%+?)%s*(.-)%s*(%d+)%s*⁄%s*(%d+)%s*$')
slashes = '/'
end
local numerator = tonumber(numstr)
local denominator = tonumber(denstr)
if numerator == nil or denominator == nil or (negative and leading_plus ~= '') then
return nil
end
local whole, wholestr
if prefix == '' then
wholestr = ''
whole = 0
else
-- Any prefix must be like '12+' or '12-' (whole number and fraction sign);
-- '12.3+' and '12.3-' are also accepted (single digit after decimal point)
-- because '12.3+1/2 hands' is valid (12 hands 3½ inches).
local num1, num2, frac_sign = prefix:match('^(%d+)(%.?%d?)%s*([+%-])$')
if num1 == nil then return nil end
if num2 == '' then -- num2 must be '' or like '.1' but not '.' or '.12'
wholestr = num1
else
if #num2 ~= 2 then return nil end
wholestr = num1 .. num2
end
if frac_sign ~= (negative and '-' or '+') then return nil end
whole = tonumber(wholestr)
if whole == nil then return nil end
end
local value = whole + numerator / denominator
if not valid_number(value) then return nil end
local altvalue = whole + numerator / (denominator * 10)
local style = #slashes -- kludge: 1 or 2 slashes can be used to select style
if style > 2 then style = 2 end
local wikitext = format_fraction(parms, 'in', negative, leading_plus .. wholestr, numstr, denstr, parms.opt_spell_in, style)
return value, altvalue, wikitext, denominator
end
local function extract_number(parms, text, another, no_fraction)
-- Return true, info if can extract a number from text,
-- where info is a table with the result,
-- or return false, t where t is an error message table.
-- Input can use en digits or digits in local language and can
-- have references at the end. Accepting references is intended
-- for use in infoboxes with a field for a value passed to convert.
-- Parameter another = true if the expected value is not the first.
-- Before processing, the input text is cleaned:
-- * Any thousand separators (valid or not) are removed.
-- * Any sign is replaced with '-' (if negative) or '' (otherwise).
-- That replaces Unicode minus with '-'.
-- If successful, the returned info table contains named fields:
-- value = a valid number
-- altvalue = a valid number, usually same as value but different
-- if fraction used (for hands unit)
-- singular = true if value is 1 or -1 (to use singular form of units)
-- clean = cleaned text with any separators and sign removed
-- (en digits and '.' decimal mark)
-- show = text formatted for output, possibly with ref strip markers
-- (digits in local language and custom decimal mark)
-- The resulting show:
-- * Is for an input value and is spelled if wanted and possible.
-- * Has a rounded value, if wanted.
-- * Has digits grouped where necessary, if wanted.
-- * If negative, a Unicode minus is used; otherwise the sign is
-- '+' (if the input text used '+'), or is '' (if no sign in input).
text = strip(text or '')
local reference
local pos = text:find('\127', 1, true)
if pos then
local before = text:sub(1, pos - 1)
local remainder = text:sub(pos)
local refs = {}
while #remainder > 0 do
local ref, spaces
ref, spaces, remainder = remainder:match('^(\127[^\127]*UNIQ[^\127]*%-ref[^\127]*\127)(%s*)(.*)')
if ref then
table.insert(refs, ref)
else
refs = {}
break
end
end
if #refs > 0 then
text = strip(before)
reference = table.concat(refs)
end
end
local clean = to_en(text, parms)
if clean == '' then
return false, { another and 'cvt_no_num2' or 'cvt_no_num' }
end
local isnegative, propersign = false, '' -- most common case
local singular, show, denominator
local value = tonumber(clean)
local altvalue
if value then
local sign = clean:sub(1, 1)
if sign == '+' or sign == '-' then
propersign = (sign == '+') and '+' or MINUS
clean = clean:sub(2)
end
if value < 0 then
isnegative = true
value = -value
end
else
local valstr
for _, prefix in ipairs({ '-', MINUS, '−' }) do
-- Including '-' sets isnegative in case input is a fraction like '-2-3/4'.
local plen = #prefix
if clean:sub(1, plen) == prefix then
valstr = clean:sub(plen + 1)
if valstr:match('^%s') then -- "- 1" is invalid but "-1 - 1/2" is ok
return false, { 'cvt_bad_num', text }
end
break
end
end
if valstr then
isnegative = true
propersign = MINUS
clean = valstr
value = tonumber(clean)
end
if value == nil then
if not no_fraction then
value, altvalue, show, denominator = extract_fraction(parms, clean, isnegative)
end
if value == nil then
return false, { 'cvt_bad_num', text }
end
if value <= 1 then
singular = true -- for example, "½ mile" or "one half mile" (singular unit)
end
end
end
if not valid_number(value) then -- for example, "1e310" may overflow
return false, { 'cvt_invalid_num' }
end
if show == nil then
-- clean is a non-empty string with no spaces, and does not represent a fraction,
-- and value = tonumber(clean) is a number >= 0.
-- If the input uses e-notation, show will be displayed using a power of ten, but
-- we use the number as given so it might not be normalized scientific notation.
-- The input value is spelled if specified so any e-notation is ignored;
-- that allows input like 2e6 to be spelled as "two million" which works
-- because the spell module converts '2e6' to '2000000' before spelling.
local function rounded(value, default, exponent)
local precision = parms.opt_ri
if precision then
local fmt = '%.' .. format('%d', precision) .. 'f'
local result = fmt:format(tonumber(value) + 2e-14) -- fudge for some common cases of bad rounding
if not exponent then
singular = (tonumber(result) == 1)
end
return result
end
return default
end
singular = (value == 1)
local scientific
local significand, exponent = clean:match('^([%d.]+)[Ee]([+%-]?%d+)')
if significand then
show = with_exponent(parms, rounded(significand, significand, exponent), exponent)
scientific = true
else
show = with_separator(parms, rounded(value, clean))
end
show = propersign .. show
if parms.opt_spell_in then
show = spell_number(parms, 'in', propersign .. rounded(value, clean)) or show
scientific = false
end
if scientific then
parms.opt_scientific = true
end
end
if isnegative and (value ~= 0) then
value = -value
altvalue = -(altvalue or value)
end
return true, {
value = value,
altvalue = altvalue or value,
singular = singular,
clean = clean,
show = show .. (reference or ''),
denominator = denominator,
}
end
local function get_number(text)
-- Return v, f where:
-- v = nil (text is not a number)
-- or
-- v = value of text (text is a number)
-- f = true if value is an integer
-- Input can use en digits or digits in local language or separators,
-- but no Unicode minus, and no fraction.
if text then
local number = tonumber(to_en(text))
if number then
local _, fracpart = math.modf(number)
return number, (fracpart == 0)
end
end
end
local function gcd(a, b)
-- Return the greatest common denominator for the given values,
-- which are known to be positive integers.
if a > b then
a, b = b, a
end
if a <= 0 then
return b
end
local r = b % a
if r <= 0 then
return a
end
if r == 1 then
return 1
end
return gcd(r, a)
end
local function fraction_table(value, denominator)
-- Return value as a string or a table:
-- * If result is a string, there is no fraction, and the result
-- is value formatted as a string of en digits.
-- * If result is a table, it represents a fraction with named fields:
-- wholestr, numstr, denstr (strings of en digits for integer, numerator, denominator).
-- The result is rounded to the nearest multiple of (1/denominator).
-- If the multiple is zero, no fraction is included.
-- No fraction is included if value is very large as the fraction would
-- be unhelpful, particularly if scientific notation is required.
-- Input value is a non-negative number.
-- Input denominator is a positive integer for the desired fraction.
if value <= 0 then
return '0'
end
if denominator <= 0 or value > 1e8 then
return format('%.2f', value)
end
local integer, decimals = math.modf(value)
local numerator = floor((decimals * denominator) +
0.5 + 2e-14) -- add fudge for some common cases of bad rounding
if numerator >= denominator then
integer = integer + 1
numerator = 0
end
local wholestr = tostring(integer)
if numerator > 0 then
local div = gcd(numerator, denominator)
if div > 1 then
numerator = numerator / div
denominator = denominator / div
end
return {
wholestr = (integer > 0) and wholestr or '',
numstr = tostring(numerator),
denstr = tostring(denominator),
value = value,
}
end
return wholestr
end
local function preunits(count, preunit1, preunit2)
-- If count is 1:
-- ignore preunit2
-- return p1
-- else:
-- preunit1 is used for preunit2 if the latter is empty
-- return p1, p2
-- where:
-- p1 is text to insert before the input unit
-- p2 is text to insert before the output unit
-- p1 or p2 may be nil to mean "no preunit"
-- Using '+' gives output like "5+ feet" (no space before, but space after).
local function withspace(text, wantboth)
-- Return text with space before and, if wantboth, after.
-- However, no space is added if there is a space or ' ' or '-'
-- at that position ('-' is for adjectival text).
-- There is also no space if text starts with '&'
-- (e.g. '°' would display a degree symbol with no preceding space).
local char = text:sub(1, 1)
if char == '&' then
return text -- an html entity can be used to specify the exact display
end
if not (char == ' ' or char == '-' or char == '+') then
text = ' ' .. text
end
if wantboth then
char = text:sub(-1, -1)
if not (char == ' ' or char == '-' or text:sub(-6, -1) == ' ') then
text = text .. ' '
end
end
return text
end
local PLUS = '+ '
preunit1 = preunit1 or ''
local trim1 = strip(preunit1)
if count == 1 then
if trim1 == '' then
return nil
end
if trim1 == '+' then
return PLUS
end
return withspace(preunit1, true)
end
preunit1 = withspace(preunit1)
preunit2 = preunit2 or ''
local trim2 = strip(preunit2)
if trim1 == '+' then
if trim2 == '' or trim2 == '+' then
return PLUS, PLUS
end
preunit1 = PLUS
end
if trim2 == '' then
if trim1 == '' then
return nil, nil
end
preunit2 = preunit1
elseif trim2 == '+' then
preunit2 = PLUS
elseif trim2 == ' ' then -- trick to make preunit2 empty
preunit2 = nil
else
preunit2 = withspace(preunit2)
end
return preunit1, preunit2
end
local function range_text(range, want_name, parms, before, after, inout, options)
-- Return before .. rtext .. after
-- where rtext is the text that separates two values in a range.
local rtext, adj_text, exception
options = options or {}
if type(range) == 'table' then
-- Table must specify range text for ('off' and 'on') or ('input' and 'output'),
-- and may specify range text for 'adj=on',
-- and may specify exception = true.
rtext = range[want_name and 'off' or 'on'] or
range[((inout == 'in') == (parms.opt_flip == true)) and 'output' or 'input']
adj_text = range['adj']
exception = range['exception']
else
rtext = range
end
if parms.opt_adjectival then
if want_name or (exception and parms.abbr_org == 'on') then
rtext = adj_text or rtext:gsub(' ', '-'):gsub(' ', '-')
end
end
if rtext == '–' and (options.spaced or after:sub(1, #MINUS) == MINUS) then
rtext = ' – '
end
return before .. rtext .. after
end
local function get_composite(parms, iparm, in_unit_table)
-- Look for a composite input unit. For example, {{convert|1|yd|2|ft|3|in}}
-- would result in a call to this function with
-- iparm = 3 (parms[iparm] = "2", just after the first unit)
-- in_unit_table = (unit table for "yd"; contains value 1 for number of yards)
-- Return true, iparm, unit where
-- iparm = index just after the composite units (7 in above example)
-- unit = composite unit table holding all input units,
-- or return true if no composite unit is present in parms,
-- or return false, t where t is an error message table.
local default, subinfo
local composite_units, count = { in_unit_table }, 1
local fixups = {}
local total = in_unit_table.valinfo[1].value
local subunit = in_unit_table
while subunit.subdivs do -- subdivs is nil or a table of allowed subdivisions
local subcode = strip(parms[iparm+1])
local subdiv = subunit.subdivs[subcode] or subunit.subdivs[(all_units[subcode] or {}).target]
if not subdiv then
break
end
local success
success, subunit = lookup(parms, subcode, 'no_combination')
if not success then return false, subunit end -- should never occur
success, subinfo = extract_number(parms, parms[iparm])
if not success then return false, subinfo end
iparm = iparm + 2
subunit.inout = 'in'
subunit.valinfo = { subinfo }
-- Recalculate total as a number of subdivisions.
-- subdiv[1] = number of subdivisions per previous unit (integer > 1).
total = total * subdiv[1] + subinfo.value
if not default then -- set by the first subdiv with a default defined
default = subdiv.default
end
count = count + 1
composite_units[count] = subunit
if subdiv.unit or subdiv.name then
fixups[count] = { unit = subdiv.unit, name = subdiv.name, valinfo = subunit.valinfo }
end
end
if count == 1 then
return true -- no error and no composite unit
end
for i, fixup in pairs(fixups) do
local unit = fixup.unit
local name = fixup.name
if not unit or (count > 2 and name) then
composite_units[i].fixed_name = name
else
local success, alternate = lookup(parms, unit, 'no_combination')
if not success then return false, alternate end -- should never occur
alternate.inout = 'in'
alternate.valinfo = fixup.valinfo
composite_units[i] = alternate
end
end
return true, iparm, {
utype = in_unit_table.utype,
scale = subunit.scale, -- scale of last (least significant) unit
valinfo = { { value = total, clean = subinfo.clean, denominator = subinfo.denominator } },
composite = composite_units,
default = default or in_unit_table.default
}
end
local function translate_parms(parms, kv_pairs)
-- Update fields in parms by translating each key:value in kv_pairs to terms
-- used by this module (may involve translating from local language to English).
-- Also, checks are performed which may display warnings, if enabled.
-- Return true if successful or return false, t where t is an error message table.
currency_text = nil -- local testing can hold module in memory; must clear globals
if kv_pairs.adj and kv_pairs.sing then
-- For enwiki (before translation), warn if attempt to use adj and sing
-- as the latter is a deprecated alias for the former.
if kv_pairs.adj ~= kv_pairs.sing and kv_pairs.sing ~= '' then
add_warning(parms, 1, 'cvt_unknown_option', 'sing=' .. kv_pairs.sing)
end
kv_pairs.sing = nil
end
kv_pairs.comma = kv_pairs.comma or config.comma -- for plwiki who want default comma=5
for loc_name, loc_value in pairs(kv_pairs) do
local en_name = text_code.en_option_name[loc_name]
if en_name then
local en_value = text_code.en_option_value[en_name]
if en_value == 'INTEGER' then -- altitude_ft, altitude_m, frac, sigfig
en_value = nil
if loc_value == '' then
add_warning(parms, 2, 'cvt_empty_option', loc_name)
else
local minimum
local number, is_integer = get_number(loc_value)
if en_name == 'sigfig' then
minimum = 1
elseif en_name == 'frac' then
minimum = 2
if number and number < 0 then
parms.opt_fraction_horizontal = true
number = -number
end
else
minimum = -1e6
end
if number and is_integer and number >= minimum then
en_value = number
else
local m
if en_name == 'frac' then
m = 'cvt_bad_frac'
elseif en_name == 'sigfig' then
m = 'cvt_bad_sigfig'
else
m = 'cvt_bad_altitude'
end
add_warning(parms, 1, m, loc_name .. '=' .. loc_value)
end
end
elseif en_value == 'TEXT' then -- $, input, qid, qual, stylein, styleout, tracking
en_value = loc_value ~= '' and loc_value or nil -- accept non-empty user text with no validation
if not en_value and (en_name == '$' or en_name == 'qid' or en_name == 'qual') then
add_warning(parms, 2, 'cvt_empty_option', loc_name)
elseif en_name == '$' then
-- Value should be a single character like "€" for the euro currency symbol, but anything is accepted.
currency_text = (loc_value == 'euro') and '€' or loc_value
elseif en_name == 'input' then
-- May have something like {{convert|input=}} (empty input) if source is an infobox
-- with optional fields. In that case, want to output nothing rather than an error.
parms.input_text = loc_value -- keep input because parms.input is nil if loc_value == ''
end
else
en_value = en_value[loc_value]
if en_value and en_value:sub(-1) == '?' then
en_value = en_value:sub(1, -2)
add_warning(parms, -1, 'cvt_deprecated', loc_name .. '=' .. loc_value)
end
if en_value == nil then
if loc_value == '' then
add_warning(parms, 2, 'cvt_empty_option', loc_name)
else
add_warning(parms, 1, 'cvt_unknown_option', loc_name .. '=' .. loc_value)
end
elseif en_value == '' then
en_value = nil -- an ignored option like adj=off
elseif type(en_value) == 'string' and en_value:sub(1, 4) == 'opt_' then
for _, v in ipairs(split(en_value, ',')) do
local lhs, rhs = v:match('^(.-)=(.+)$')
if rhs then
parms[lhs] = tonumber(rhs) or rhs
else
parms[v] = true
end
end
en_value = nil
end
end
parms[en_name] = en_value
else
add_warning(parms, 1, 'cvt_unknown_option', loc_name .. '=' .. loc_value)
end
end
local abbr_entered = parms.abbr
local cfg_abbr = config.abbr
if cfg_abbr then
-- Don't warn if invalid because every convert would show that warning.
if cfg_abbr == 'on always' then
parms.abbr = 'on'
elseif cfg_abbr == 'off always' then
parms.abbr = 'off'
elseif parms.abbr == nil then
if cfg_abbr == 'on default' then
parms.abbr = 'on'
elseif cfg_abbr == 'off default' then
parms.abbr = 'off'
end
end
end
if parms.abbr then
if parms.abbr == 'unit' then
parms.abbr = 'on'
parms.number_word = true
end
parms.abbr_org = parms.abbr -- original abbr, before any flip
elseif parms.opt_hand_hh then
parms.abbr_org = 'on'
parms.abbr = 'on'
else
parms.abbr = 'out' -- default is to abbreviate output only (use symbol, not name)
end
if parms.opt_order_out then
-- Disable options that do not work in a useful way with order=out.
parms.opt_flip = nil -- override adj=flip
parms.opt_spell_in = nil
parms.opt_spell_out = nil
parms.opt_spell_upper = nil
end
if parms.opt_spell_out and not abbr_entered then
parms.abbr = 'off' -- should show unit name when spelling the output value
end
if parms.opt_flip then
local function swap_in_out(option)
local value = parms[option]
if value == 'in' then
parms[option] = 'out'
elseif value == 'out' then
parms[option] = 'in'
end
end
swap_in_out('abbr')
swap_in_out('lk')
if parms.opt_spell_in and not parms.opt_spell_out then
-- For simplicity, and because it does not appear to be needed,
-- user cannot set an option to spell the output only.
parms.opt_spell_in = nil
parms.opt_spell_out = true
end
end
if parms.opt_spell_upper then
parms.spell_upper = parms.opt_flip and 'out' or 'in'
end
if parms.opt_table or parms.opt_tablecen then
if abbr_entered == nil and parms.lk == nil then
parms.opt_values = true
end
parms.table_align = parms.opt_table and 'right' or 'center'
end
if parms.table_align or parms.opt_sortable_on then
parms.need_table_or_sort = true
end
local disp_joins = text_code.disp_joins
local default_joins = disp_joins['b']
parms.join_between = default_joins[3] or '; '
local disp = parms.disp
if disp == nil then -- special case for the most common setting
parms.joins = default_joins
elseif disp == 'x' then
-- Later, parms.joins is set from the input parameters.
else
-- Old template does this.
local abbr = parms.abbr
if disp == 'slash' then
if abbr_entered == nil then
disp = 'slash-nbsp'
elseif abbr == 'in' or abbr == 'out' then
disp = 'slash-sp'
else
disp = 'slash-nosp'
end
elseif disp == 'sqbr' then
if abbr == 'on' then
disp = 'sqbr-nbsp'
else
disp = 'sqbr-sp'
end
end
parms.joins = disp_joins[disp] or default_joins
parms.join_between = parms.joins[3] or parms.join_between
parms.wantname = parms.joins.wantname
end
if (en_default and not parms.opt_lang_local and (parms[1] or ''):find('%d')) or parms.opt_lang_en then
from_en_table = nil
end
if en_default and from_en_table then
-- For hiwiki: localized symbol/name is defined with the US symbol/name field,
-- and is used if output uses localized numbers.
parms.opt_sp_us = true
end
return true
end
local function get_values(parms)
-- If successful, update parms and return true, v, i where
-- v = table of input values
-- i = index to next entry in parms after those processed here
-- or return false, t where t is an error message table.
local valinfo = collection() -- numbered table of input values
local range = collection() -- numbered table of range items (having, for example, 2 range items requires 3 input values)
local had_nocomma -- true if removed "nocomma" kludge from second parameter (like "tonocomma")
local parm2 = strip(parms[2])
if parm2 and parm2:sub(-7, -1) == 'nocomma' then
parms[2] = strip(parm2:sub(1, -8))
parms.opt_nocomma = true
had_nocomma = true
end
local function extractor(i)
-- If the parameter is not a value, try unpacking it as a range ("1-23" for "1 to 23").
-- However, "-1-2/3" is a negative fraction (-1⅔), so it must be extracted first.
-- Do not unpack a parameter if it is like "3-1/2" which is sometimes incorrectly
-- used instead of "3+1/2" (and which should not be interpreted as "3 to ½").
-- Unpacked items are inserted into the parms table.
-- The tail recursion allows combinations like "1x2 to 3x4".
local valstr = strip(parms[i]) -- trim so any '-' as a negative sign will be at start
local success, result = extract_number(parms, valstr, i > 1)
if not success and valstr and i < 20 then -- check i to limit abuse
local lhs, sep, rhs = valstr:match('^(%S+)%s+(%S+)%s+(%S.*)')
if lhs and not (sep == '-' and rhs:match('/')) then
if sep:find('%d') then
return success, result -- to reject {{convert|1 234 567|m}} with a decent message (en only)
end
parms[i] = rhs
table.insert(parms, i, sep)
table.insert(parms, i, lhs)
return extractor(i)
end
if not valstr:match('%-.*/') then
for _, sep in ipairs(text_code.ranges.words) do
local start, stop = valstr:find(sep, 2, true) -- start at 2 to skip any negative sign for range '-'
if start then
parms[i] = valstr:sub(stop + 1)
table.insert(parms, i, sep)
table.insert(parms, i, valstr:sub(1, start - 1))
return extractor(i)
end
end
end
end
return success, result
end
local i = 1
local is_change
while true do
local success, info = extractor(i) -- need to set parms.opt_nocomma before calling this
if not success then return false, info end
i = i + 1
if is_change then
info.is_change = true -- value is after "±" and so is a change (significant for range like {{convert|5|±|5|°C}})
is_change = nil
end
valinfo:add(info)
local range_item = get_range(strip(parms[i]))
if not range_item then
break
end
i = i + 1
range:add(range_item)
if type(range_item) == 'table' then
-- For range "x", if append unit to some values, append it to all.
parms.in_range_x = parms.in_range_x or range_item.in_range_x
parms.out_range_x = parms.out_range_x or range_item.out_range_x
parms.abbr_range_x = parms.abbr_range_x or range_item.abbr_range_x
is_change = range_item.is_range_change
end
end
if range.n > 0 then
if range.n > 30 then -- limit abuse, although 4 is a more likely upper limit
return false, { 'cvt_invalid_num' } -- misleading message but it will do
end
parms.range = range
elseif had_nocomma then
return false, { 'cvt_unknown', parm2 }
end
return true, valinfo, i
end
local function simple_get_values(parms)
-- If input is like "{{convert|valid_value|valid_unit|...}}",
-- return true, i, in_unit, in_unit_table
-- i = index in parms of what follows valid_unit, if anything.
-- The valid_value is not negative and does not use a fraction, and
-- no options requiring further processing of the input are used.
-- Otherwise, return nothing or return false, parm1 for caller to interpret.
-- Testing shows this function is successful for 96% of converts in articles,
-- and that on average it speeds up converts by 8%.
local clean = to_en(strip(parms[1] or ''), parms)
if parms.opt_ri or parms.opt_spell_in or #clean > 10 or not clean:match('^[0-9.]+$') then
return false, clean
end
local value = tonumber(clean)
if not value then return end
local info = {
value = value,
altvalue = value,
singular = (value == 1),
clean = clean,
show = with_separator(parms, clean),
}
local in_unit = strip(parms[2])
local success, in_unit_table = lookup(parms, in_unit, 'no_combination')
if not success then return end
in_unit_table.valinfo = { info }
return true, 3, in_unit, in_unit_table
end
local function wikidata_call(parms, operation, ...)
-- Return true, s where s is the result of a Wikidata operation,
-- or return false, t where t is an error message table.
local function worker(...)
wikidata_code = wikidata_code or require(wikidata_module)
wikidata_data = wikidata_data or mw.loadData(wikidata_data_module)
return wikidata_code[operation](wikidata_data, ...)
end
local success, status, result = pcall(worker, ...)
if success then
return status, result
end
if parms.opt_sortable_debug then
-- Use debug=yes to crash if an error while accessing Wikidata.
error('Error accessing Wikidata: ' .. status, 0)
end
return false, { 'cvt_wd_fail' }
end
local function get_parms(parms, args)
-- If successful, update parms and return true, unit where
-- parms is a table of all arguments passed to the template
-- converted to named arguments, and
-- unit is the input unit table;
-- or return false, t where t is an error message table.
-- For special processing (not a convert), can also return
-- true, wikitext where wikitext is the final result.
-- The returned input unit table may be for a fake unit using the specified
-- unit code as the symbol and name, and with bad_mcode = message code table.
-- MediaWiki removes leading and trailing whitespace from the values of
-- named arguments. However, the values of numbered arguments include any
-- whitespace entered in the template, and whitespace is used by some
-- parameters (example: the numbered parameters associated with "disp=x").
local kv_pairs = {} -- table of input key:value pairs where key is a name; needed because cannot iterate parms and add new fields to it
for k, v in pairs(args) do
if type(k) == 'number' or k == 'test' then -- parameter "test" is reserved for testing and is not translated
parms[k] = v
else
kv_pairs[k] = v
end
end
if parms.test == 'wikidata' then
local ulookup = function (ucode)
-- Use empty table for parms so it does not accumulate results when used repeatedly.
return lookup({}, ucode, 'no_combination')
end
return wikidata_call(parms, '_listunits', ulookup)
end
local success, msg = translate_parms(parms, kv_pairs)
if not success then return false, msg end
if parms.input then
success, msg = wikidata_call(parms, '_adjustparameters', parms, 1)
if not success then return false, msg end
end
local success, i, in_unit, in_unit_table = simple_get_values(parms)
if not success then
if type(i) == 'string' and i:match('^NNN+$') then
-- Some infoboxes have examples like {{convert|NNN|m}} (3 or more "N").
-- Output an empty string for these.
return false, { 'cvt_no_output' }
end
local valinfo
success, valinfo, i = get_values(parms)
if not success then return false, valinfo end
in_unit = strip(parms[i])
i = i + 1
success, in_unit_table = lookup(parms, in_unit, 'no_combination')
if not success then
in_unit = in_unit or ''
if parms.opt_ignore_error then -- display given unit code with no error (for use with {{val}})
in_unit_table = '' -- suppress error message and prevent processing of output unit
end
in_unit_table = setmetatable({
symbol = in_unit, name2 = in_unit, utype = in_unit,
scale = 1, default = '', defkey = '', linkey = '',
bad_mcode = in_unit_table }, unit_mt)
end
in_unit_table.valinfo = valinfo
end
if parms.test == 'msg' then
-- Am testing the messages produced when no output unit is specified, and
-- the input unit has a missing or invalid default.
-- Set two units for testing that.
-- LATER: Remove this code.
if in_unit == 'chain' then
in_unit_table.default = nil -- no default
elseif in_unit == 'rd' then
in_unit_table.default = "ft!X!m" -- an invalid expression
end
end
in_unit_table.inout = 'in' -- this is an input unit
if not parms.range then
local success, inext, composite_unit = get_composite(parms, i, in_unit_table)
if not success then return false, inext end
if composite_unit then
in_unit_table = composite_unit
i = inext
end
end
if in_unit_table.builtin == 'mach' then
-- As with old template, a number following Mach as the input unit is the altitude.
-- That is deprecated: should use altitude_ft=NUMBER or altitude_m=NUMBER.
local success, info
success = tonumber(parms[i]) -- this will often work and will give correct result for values like 2e4 without forcing output scientific notation
if success then
info = { value = success }
else
success, info = extract_number(parms, parms[i], false, true)
end
if success then
i = i + 1
in_unit_table.altitude = info.value
end
end
local word = strip(parms[i])
i = i + 1
local precision, is_bad_precision
local function set_precision(text)
local number, is_integer = get_number(text)
if number then
if is_integer then
precision = number
else
precision = text
is_bad_precision = true
end
return true -- text was used for precision, good or bad
end
end
if word and not set_precision(word) then
parms.out_unit = parms.out_unit or word
if set_precision(strip(parms[i])) then
i = i + 1
end
end
if parms.opt_adj_mid then
word = parms[i]
i = i + 1
if word then -- mid-text words
if word:sub(1, 1) == '-' then
parms.mid = word
else
parms.mid = ' ' .. word
end
end
end
if parms.opt_one_preunit then
parms[parms.opt_flip and 'preunit2' or 'preunit1'] = preunits(1, parms[i])
i = i + 1
end
if parms.disp == 'x' then
-- Following is reasonably compatible with the old template.
local first = parms[i] or ''
local second = parms[i+1] or ''
i = i + 2
if strip(first) == '' then -- user can enter ' ' rather than ' ' to avoid the default
first = ' [ ' .. first
second = ' ]' .. second
end
parms.joins = { first, second }
elseif parms.opt_two_preunits then
local p1, p2 = preunits(2, parms[i], parms[i+1])
i = i + 2
if parms.preunit1 then
-- To simplify documentation, allow unlikely use of adj=pre with disp=preunit
-- (however, an output unit must be specified with adj=pre and with disp=preunit).
parms.preunit1 = parms.preunit1 .. p1
parms.preunit2 = p2
else
parms.preunit1, parms.preunit2 = p1, p2
end
end
if precision == nil then
if set_precision(strip(parms[i])) then
i = i + 1
end
end
if is_bad_precision then
add_warning(parms, 1, 'cvt_bad_prec', precision)
else
parms.precision = precision
end
for j = i, i + 3 do
local parm = parms[j] -- warn if find a non-empty extraneous parameter
if parm and parm:match('%S') then
add_warning(parms, 1, 'cvt_unknown_option', parm)
break
end
end
return true, in_unit_table
end
local function record_default_precision(parms, out_current, precision)
-- If necessary, adjust parameters and return a possibly adjusted precision.
-- When converting a range of values where a default precision is required,
-- that default is calculated for each value because the result sometimes
-- depends on the precise input and output values. This function may cause
-- the entire convert process to be repeated in order to ensure that the
-- same default precision is used for each individual convert.
-- If that were not done, a range like 1000 to 1000.4 may give poor results
-- because the first output could be heavily rounded, while the second is not.
-- For range 1000.4 to 1000, this function can give the second convert the
-- same default precision that was used for the first.
if not parms.opt_round_each then
local maxdef = out_current.max_default_precision
if maxdef then
if maxdef < precision then
parms.do_convert_again = true
out_current.max_default_precision = precision
else
precision = out_current.max_default_precision
end
else
out_current.max_default_precision = precision
end
end
return precision
end
local function default_precision(parms, invalue, inclean, denominator, outvalue, in_current, out_current, extra)
-- Return a default value for precision (an integer like 2, 0, -2).
-- If denominator is not nil, it is the value of the denominator in inclean.
-- Code follows procedures used in old template.
local fudge = 1e-14 -- {{Order of magnitude}} adds this, so we do too
local prec, minprec, adjust
local subunit_ignore_trailing_zero
local subunit_more_precision -- kludge for "in" used in input like "|2|ft|6|in"
local composite = in_current.composite
if composite then
subunit_ignore_trailing_zero = true -- input "|2|st|10|lb" has precision 0, not -1
if composite[#composite].exception == 'subunit_more_precision' then
subunit_more_precision = true -- do not use standard precision with input like "|2|ft|6|in"
end
end
if denominator and denominator > 0 then
prec = math.max(log10(denominator), 1)
else
-- Count digits after decimal mark, handling cases like '12.345e6'.
local exponent
local integer, dot, decimals, expstr = inclean:match('^(%d*)(%.?)(%d*)(.*)')
local e = expstr:sub(1, 1)
if e == 'e' or e == 'E' then
exponent = tonumber(expstr:sub(2))
end
if dot == '' then
prec = subunit_ignore_trailing_zero and 0 or -integer:match('0*$'):len()
else
prec = #decimals
end
if exponent then
-- So '1230' and '1.23e3' both give prec = -1, and '0.00123' and '1.23e-3' give 5.
prec = prec - exponent
end
end
if in_current.istemperature and out_current.istemperature then
-- Converting between common temperatures (°C, °F, °R, K); not keVT.
-- Kelvin value can be almost zero, or small but negative due to precision problems.
-- Also, an input value like -300 C (below absolute zero) gives negative kelvins.
-- Calculate minimum precision from absolute value.
adjust = 0
local kelvin = abs((invalue - in_current.offset) * in_current.scale)
if kelvin < 1e-8 then -- assume nonzero due to input or calculation precision problem
minprec = 2
else
minprec = 2 - floor(log10(kelvin) + fudge) -- 3 sigfigs in kelvin
end
else
if invalue == 0 or outvalue <= 0 then
-- We are never called with a negative outvalue, but it might be zero.
-- This is special-cased to avoid calculation exceptions.
return record_default_precision(parms, out_current, 0)
end
if out_current.exception == 'integer_more_precision' and floor(invalue) == invalue then
-- With certain output units that sometimes give poor results
-- with default rounding, use more precision when the input
-- value is equal to an integer. An example of a poor result
-- is when input 50 gives a smaller output than input 49.5.
-- Experiment shows this helps, but it does not eliminate all
-- surprises because it is not clear whether "50" should be
-- interpreted as "from 45 to 55" or "from 49.5 to 50.5".
adjust = -log10(in_current.scale)
elseif subunit_more_precision then
-- Conversion like "{{convert|6|ft|1|in|cm}}" (where subunit is "in")
-- has a non-standard adjust value, to give more output precision.
adjust = log10(out_current.scale) + 2
else
adjust = log10(abs(invalue / outvalue))
end
adjust = adjust + log10(2)
-- Ensure that the output has at least two significant figures.
minprec = 1 - floor(log10(outvalue) + fudge)
end
if extra then
adjust = extra.adjust or adjust
minprec = extra.minprec or minprec
end
return record_default_precision(parms, out_current, math.max(floor(prec + adjust), minprec))
end
local function convert(parms, invalue, info, in_current, out_current)
-- Convert given input value from one unit to another.
-- Return output_value (a number) if a simple convert, or
-- return f, t where
-- f = true, t = table of information with results, or
-- f = false, t = error message table.
local inscale = in_current.scale
local outscale = out_current.scale
if not in_current.iscomplex and not out_current.iscomplex then
return invalue * (inscale / outscale) -- minimize overhead for most common case
end
if in_current.invert or out_current.invert then
-- Inverted units, such as inverse length, inverse time, or
-- fuel efficiency. Built-in units do not have invert set.
if (in_current.invert or 1) * (out_current.invert or 1) < 0 then
return 1 / (invalue * inscale * outscale)
end
return invalue * (inscale / outscale)
elseif in_current.offset then
-- Temperature (there are no built-ins for this type of unit).
if info.is_change then
return invalue * (inscale / outscale)
end
return (invalue - in_current.offset) * (inscale / outscale) + out_current.offset
else
-- Built-in unit.
local in_builtin = in_current.builtin
local out_builtin = out_current.builtin
if in_builtin and out_builtin then
if in_builtin == out_builtin then
return invalue
end
-- There are no cases (yet) where need to convert from one
-- built-in unit to another, so this should never occur.
return false, { 'cvt_bug_convert' }
end
if in_builtin == 'mach' or out_builtin == 'mach' then
-- Should check that only one altitude is given but am planning to remove
-- in_current.altitude (which can only occur when Mach is the input unit),
-- and out_current.altitude cannot occur.
local alt = parms.altitude_ft or in_current.altitude
if not alt and parms.altitude_m then
alt = parms.altitude_m / 0.3048 -- 1 ft = 0.3048 m
end
local spd = speed_of_sound(alt)
if in_builtin == 'mach' then
inscale = spd
return invalue * (inscale / outscale)
end
outscale = spd
local adjust = 0.1 / inscale
return true, {
outvalue = invalue * (inscale / outscale),
adjust = log10(adjust) + log10(2),
}
elseif in_builtin == 'hand' then
-- 1 hand = 4 inches; 1.2 hands = 6 inches.
-- Decimals of a hand are only defined for the first digit, and
-- the first fractional digit should be a number of inches (1, 2 or 3).
-- However, this code interprets the entire fractional part as the number
-- of inches / 10 (so 1.75 inches would be 0.175 hands).
-- A value like 12.3 hands is exactly 12*4 + 3 inches; base default precision on that.
local integer, fracpart = math.modf(invalue)
local inch_value = 4 * integer + 10 * fracpart -- equivalent number of inches
local factor = inscale / outscale
if factor == 4 then
-- Am converting to inches: show exact result, and use "inches" not "in" by default.
if parms.abbr_org == nil then
out_current.usename = true
end
local show = format('%g', abs(inch_value)) -- show and clean are unsigned
if not show:find('e', 1, true) then
return true, {
invalue = inch_value,
outvalue = inch_value,
clean = show,
show = show,
}
end
end
local outvalue = (integer + 2.5 * fracpart) * factor
local fracstr = info.clean:match('%.(.*)') or ''
local fmt
if fracstr == '' then
fmt = '%.0f'
else
fmt = '%.' .. format('%d', #fracstr - 1) .. 'f'
end
return true, {
invalue = inch_value,
clean = format(fmt, inch_value),
outvalue = outvalue,
minprec = 0,
}
end
end
return false, { 'cvt_bug_convert' } -- should never occur
end
local function user_style(parms, i)
-- Return text for a user-specified style for a table cell, or '' if none,
-- given i = 1 (input style) or 2 (output style).
local style = parms[(i == 1) and 'stylein' or 'styleout']
if style then
style = style:gsub('"', '')
if style ~= '' then
if style:sub(-1) ~= ';' then
style = style .. ';'
end
return style
end
end
return ''
end
local function make_table_or_sort(parms, invalue, info, in_current, scaled_top)
-- Set options to handle output for a table or a sort key, or both.
-- The text sort key is based on the value resulting from converting
-- the input to a fake base unit with scale = 1, and other properties
-- required for a conversion derived from the input unit.
-- For other modules, return the sort key in a hidden span element, and
-- the scaled value used to generate the sort key.
-- If scaled_top is set, it is the scaled value of the numerator of a per unit
-- to be combined with this unit (the denominator) to make the sort key.
-- Scaling only works with units that convert with a factor (not temperature).
local sortkey, scaled_value
if parms.opt_sortable_on then
local base = { -- a fake unit with enough fields for a valid convert
scale = 1,
invert = in_current.invert and 1,
iscomplex = in_current.iscomplex,
offset = in_current.offset and 0,
}
local outvalue, extra = convert(parms, invalue, info, in_current, base)
if extra then
outvalue = extra.outvalue
end
if in_current.istemperature then
-- Have converted to kelvin; assume numbers close to zero have a
-- rounding error and should be zero.
if abs(outvalue) < 1e-12 then
outvalue = 0
end
end
if scaled_top and outvalue ~= 0 then
outvalue = scaled_top / outvalue
end
scaled_value = outvalue
if not valid_number(outvalue) then
if outvalue < 0 then
sortkey = '1000000000000000000'
else
sortkey = '9000000000000000000'
end
elseif outvalue == 0 then
sortkey = '5000000000000000000'
else
local mag = floor(log10(abs(outvalue)) + 1e-14)
local prefix
if outvalue > 0 then
prefix = 7000 + mag
else
prefix = 2999 - mag
outvalue = outvalue + 10^(mag+1)
end
sortkey = format('%d', prefix) .. format('%015.0f', floor(outvalue * 10^(14-mag)))
end
end
local sortspan
if sortkey and not parms.table_align then
sortspan = parms.opt_sortable_debug and
'<span data-sort-value="' .. sortkey .. '♠"><span style="border:1px solid">' .. sortkey .. '♠</span></span>' or
'<span data-sort-value="' .. sortkey .. '♠"></span>'
parms.join_before = sortspan
end
if parms.table_align then
local sort
if sortkey then
sort = ' data-sort-value="' .. sortkey .. '"'
if parms.opt_sortable_debug then
parms.join_before = '<span style="border:1px solid">' .. sortkey .. '</span>'
end
else
sort = ''
end
local style = 'style="text-align:' .. parms.table_align .. ';'
local joins = {}
for i = 1, 2 do
joins[i] = (i == 1 and '' or '\n|') .. style .. user_style(parms, i) .. '"' .. sort .. '|'
end
parms.table_joins = joins
end
return sortspan, scaled_value
end
local cvt_to_hand
local function cvtround(parms, info, in_current, out_current)
-- Return true, t where t is a table with the conversion results; fields:
-- show = rounded, formatted string with the result of converting value in info,
-- using the rounding specified in parms.
-- singular = true if result (after rounding and ignoring any negative sign)
-- is "1", or like "1.00", or is a fraction with value < 1;
-- (and more fields shown below, and a calculated 'absvalue' field).
-- or return false, t where t is an error message table.
-- Input info.clean uses en digits (it has been translated, if necessary).
-- Output show uses en or non-en digits as appropriate, or can be spelled.
if out_current.builtin == 'hand' then
return cvt_to_hand(parms, info, in_current, out_current)
end
local invalue = in_current.builtin == 'hand' and info.altvalue or info.value
local outvalue, extra = convert(parms, invalue, info, in_current, out_current)
if parms.need_table_or_sort then
parms.need_table_or_sort = nil -- process using first input value only
make_table_or_sort(parms, invalue, info, in_current)
end
if extra then
if not outvalue then return false, extra end
invalue = extra.invalue or invalue
outvalue = extra.outvalue
end
if not valid_number(outvalue) then
return false, { 'cvt_invalid_num' }
end
local isnegative
if outvalue < 0 then
isnegative = true
outvalue = -outvalue
end
local precision, show, exponent
local denominator = out_current.frac
if denominator then
show = fraction_table(outvalue, denominator)
else
precision = parms.precision
if not precision then
if parms.sigfig then
show, exponent = make_sigfig(outvalue, parms.sigfig)
elseif parms.opt_round then
local n = parms.opt_round
if n == 0.5 then
local integer, fracpart = math.modf(floor(2 * outvalue + 0.5) / 2)
if fracpart == 0 then
show = format('%.0f', integer)
else
show = format('%.1f', integer + fracpart)
end
else
show = format('%.0f', floor((outvalue / n) + 0.5) * n)
end
elseif in_current.builtin == 'mach' then
local sigfig = info.clean:gsub('^[0.]+', ''):gsub('%.', ''):len() + 1
show, exponent = make_sigfig(outvalue, sigfig)
else
local inclean = info.clean
if extra then
inclean = extra.clean or inclean
show = extra.show
end
if not show then
precision = default_precision(parms, invalue, inclean, info.denominator, outvalue, in_current, out_current, extra)
end
end
end
end
if precision then
if precision >= 0 then
local fudge
if precision <= 8 then
-- Add a fudge to handle common cases of bad rounding due to inability
-- to precisely represent some values. This makes the following work:
-- {{convert|-100.1|C|K}} and {{convert|5555000|um|m|2}}.
-- Old template uses #expr round, which invokes PHP round().
-- LATER: Investigate how PHP round() works.
fudge = 2e-14
else
fudge = 0
end
local fmt = '%.' .. format('%d', precision) .. 'f'
local success
success, show = pcall(format, fmt, outvalue + fudge)
if not success then
return false, { 'cvt_big_prec', tostring(precision) }
end
else
precision = -precision -- #digits to zero (in addition to any digits after dot)
local shift = 10 ^ precision
show = format('%.0f', outvalue/shift)
if show ~= '0' then
exponent = #show + precision
end
end
end
local t = format_number(parms, show, exponent, isnegative)
if type(show) == 'string' then
-- Set singular using match because on some systems 0.99999999999999999 is 1.0.
if exponent then
t.singular = (exponent == 1 and show:match('^10*$'))
else
t.singular = (show == '1' or show:match('^1%.0*$'))
end
else
t.fraction_table = show
t.singular = (outvalue <= 1) -- cannot have 'fraction == 1', but if it were possible it would be singular
end
t.raw_absvalue = outvalue -- absolute value before rounding
return true, setmetatable(t, {
__index = function (self, key)
if key == 'absvalue' then
-- Calculate absolute value after rounding, if needed.
local clean, exponent = rawget(self, 'clean'), rawget(self, 'exponent')
local value = tonumber(clean) -- absolute value (any negative sign has been ignored)
if exponent then
value = value * 10^exponent
end
rawset(self, key, value)
return value
end
end })
end
function cvt_to_hand(parms, info, in_current, out_current)
-- Convert input to hands, inches.
-- Return true, t where t is a table with the conversion results;
-- or return false, t where t is an error message table.
if parms.abbr_org == nil then
out_current.usename = true -- default is to show name not symbol
end
local precision = parms.precision
local frac = out_current.frac
if not frac and precision and precision > 1 then
frac = (precision == 2) and 2 or 4
end
local out_next = out_current.out_next
if out_next then
-- Use magic knowledge to determine whether the next unit is inches without requiring i18n.
-- The following ensures that when the output combination "hand in" is used, the inches
-- value is rounded to match the hands value. Also, displaying say "61½" instead of 61.5
-- is better as 61.5 implies the value is not 61.4.
if out_next.exception == 'subunit_more_precision' then
out_next.frac = frac
end
end
-- Convert to inches; calculate hands from that.
local dummy_unit_table = { scale = out_current.scale / 4, frac = frac }
local success, outinfo = cvtround(parms, info, in_current, dummy_unit_table)
if not success then return false, outinfo end
local tfrac = outinfo.fraction_table
local inches = outinfo.raw_absvalue
if tfrac then
inches = floor(inches) -- integer part only; fraction added later
else
inches = floor(inches + 0.5) -- a hands measurement never shows decimals of an inch
end
local hands, inches = divide(inches, 4)
outinfo.absvalue = hands + inches/4 -- supposed to be the absolute rounded value, but this is close enough
local inchstr = tostring(inches) -- '0', '1', '2' or '3'
if precision and precision <= 0 then -- using negative or 0 for precision rounds to nearest hand
hands = floor(outinfo.raw_absvalue/4 + 0.5)
inchstr = ''
elseif tfrac then
-- Always show an integer before fraction (like "15.0½") because "15½" means 15-and-a-half hands.
inchstr = numdot .. format_fraction(parms, 'out', false, inchstr, tfrac.numstr, tfrac.denstr)
else
inchstr = numdot .. from_en(inchstr)
end
outinfo.show = outinfo.sign .. with_separator(parms, format('%.0f', hands)) .. inchstr
return true, outinfo
end
local function evaluate_condition(value, condition)
-- Return true or false from applying a conditional expression to value,
-- or throw an error if invalid.
-- A very limited set of expressions is supported:
-- v < 9
-- v * 9 < 9
-- where
-- 'v' is replaced with value
-- 9 is any number (as defined by Lua tonumber)
-- only en digits are accepted
-- '<' can also be '<=' or '>' or '>='
-- In addition, the following form is supported:
-- LHS and RHS
-- where
-- LHS, RHS = any of above expressions.
local function compare(value, text)
local arithop, factor, compop, limit = text:match('^%s*v%s*([*]?)(.-)([<>]=?)(.*)$')
if arithop == nil then
error('Invalid default expression', 0)
elseif arithop == '*' then
factor = tonumber(factor)
if factor == nil then
error('Invalid default expression', 0)
end
value = value * factor
end
limit = tonumber(limit)
if limit == nil then
error('Invalid default expression', 0)
end
if compop == '<' then
return value < limit
elseif compop == '<=' then
return value <= limit
elseif compop == '>' then
return value > limit
elseif compop == '>=' then
return value >= limit
end
error('Invalid default expression', 0) -- should not occur
end
local lhs, rhs = condition:match('^(.-%W)and(%W.*)')
if lhs == nil then
return compare(value, condition)
end
return compare(value, lhs) and compare(value, rhs)
end
local function get_default(value, unit_table)
-- Return true, s where s = name of unit's default output unit,
-- or return false, t where t is an error message table.
-- Some units have a default that depends on the input value
-- (the first value if a range of values is used).
-- If '!' is in the default, the first bang-delimited field is an
-- expression that uses 'v' to represent the input value.
-- Example: 'v < 120 ! small ! big ! suffix' (suffix is optional)
-- evaluates 'v < 120' as a boolean with result
-- 'smallsuffix' if (value < 120), or 'bigsuffix' otherwise.
-- Input must use en digits and '.' decimal mark.
local default = data_code.default_exceptions[unit_table.defkey or unit_table.symbol] or unit_table.default
if not default then
local per = unit_table.per
if per then
local function a_default(v, u)
local success, ucode = get_default(v, u)
if not success then
return '?' -- an unlikely error has occurred; will cause lookup of default to fail
end
-- Attempt to use only the first unit if a combination or output multiple.
-- This is not bulletproof but should work for most cases.
-- Where it does not work, the convert will need to specify the wanted output unit.
local t = all_units[ucode]
if t then
local combo = t.combination
if combo then
-- For a multiple like ftin, the "first" unit (ft) is last in the combination.
local i = t.multiple and table_len(combo) or 1
ucode = combo[i]
end
else
-- Try for an automatically generated combination.
local item = ucode:match('^(.-)%+') or ucode:match('^(%S+)%s')
if all_units[item] then
return item
end
end
return ucode
end
local unit1, unit2 = per[1], per[2]
local def1 = (unit1 and a_default(value, unit1) or unit_table.vprefix or '')
local def2 = a_default(1, unit2) -- 1 because per unit of denominator
return true, def1 .. '/' .. def2
end
return false, { 'cvt_no_default', unit_table.symbol }
end
if default:find('!', 1, true) == nil then
return true, default
end
local t = split(default, '!')
if #t == 3 or #t == 4 then
local success, result = pcall(evaluate_condition, value, t[1])
if success then
default = result and t[2] or t[3]
if #t == 4 then
default = default .. t[4]
end
return true, default
end
end
return false, { 'cvt_bad_default', unit_table.symbol }
end
local linked_pages -- to record linked pages so will not link to the same page more than once
local function unlink(unit_table)
-- Forget that the given unit has previously been linked (if it has).
-- That is needed when processing a range of inputs or outputs when an id
-- for the first range value may have been evaluated, but only an id for
-- the last value is displayed, and that id may need to be linked.
linked_pages[unit_table.unitcode or unit_table] = nil
end
local function make_link(link, id, unit_table)
-- Return wikilink "[[link|id]]", possibly abbreviated as in examples:
-- [[Mile|mile]] --> [[mile]]
-- [[Mile|miles]] --> [[mile]]s
-- However, just id is returned if:
-- * no link given (so caller does not need to check if a link was defined); or
-- * link has previously been used during the current convert (to avoid overlinking).
local link_key
if unit_table then
link_key = unit_table.unitcode or unit_table
else
link_key = link
end
if not link or link == '' or linked_pages[link_key] then
return id
end
linked_pages[link_key] = true
-- Following only works for language en, but it should be safe on other wikis,
-- and overhead of doing it generally does not seem worthwhile.
local l = link:sub(1, 1):lower() .. link:sub(2)
if link == id or l == id then
return '[[' .. id .. ']]'
elseif link .. 's' == id or l .. 's' == id then
return '[[' .. id:sub(1, -2) .. ']]s'
else
return '[[' .. link .. '|' .. id .. ']]'
end
end
local function variable_name(clean, unit_table, exp_multiplier, key_id)
-- A unit name may depend on the value in some languages.
-- Parameter clean is the unsigned value in en digits, as a string.
-- It may represent a number ("1.0") or a fraction ("1+2/3").
-- In varname, fields are separated with "!" and are not empty.
-- A field for a unit using an SI prefix has the prefix name inserted,
-- replacing '#' if found, or before the field otherwise.
if clean:match('[./]') then -- float or fraction
if exp_multiplier then
clean = exp_multiplier -- force selection of name for a large integer
else
clean = 34.5 -- force selection of name for a float value
end
else
clean = tonumber(clean) * (exp_multiplier or 1)
end
local name1, vname
if key_id == 'pername' and unit_table.pername then
vname = unit_table.pername
elseif unit_table.varname then
local splitvname = split(unit_table.varname, '!')
name1 = unit_table.name1
vname = mw.language.getContentLanguage():convertPlural(clean, name1, unpack(splitvname))
else
return clean == 1 and unit_table.name1 or unit_table.name2
end
if vname == name1 then
-- SI prefix (if any) has been inserted by unit_prefixed_mt.
else
local si_name = rawget(unit_table, 'si_name') or ''
local pos = vname:find('#', 1, true)
if pos then
vname = vname:sub(1, pos - 1) .. si_name .. vname:sub(pos + 1)
else
vname = si_name .. vname
end
end
return vname
end
local function linked_id(parms, unit_table, key_id, want_link, clean, exp_multiplier)
-- Return final unit id (symbol or name), optionally with a wikilink,
-- and update unit_table.sep if required.
-- key_id is one of: 'symbol', 'sym_us', 'name1', 'name1_us', 'name2', 'name2_us', 'pername'.
local abbr_on = (key_id == 'symbol' or key_id == 'sym_us')
if abbr_on and want_link then
local symlink = rawget(unit_table, 'symlink')
if symlink then
return symlink -- for exceptions that have the linked symbol built-in
end
end
local multiplier = rawget(unit_table, 'multiplier')
local per = unit_table.per
if per then
local paren1, paren2 = '', '' -- possible parentheses around bottom unit
local unit1 = per[1] -- top unit_table, or nil
local unit2 = per[2] -- bottom unit_table
if abbr_on then
if not unit1 then
unit_table.sep = '' -- no separator in "$2/acre"
end
if not want_link then
local symbol = unit_table.symbol_raw
if symbol then
return symbol -- for exceptions that have the symbol built-in
end
end
if (unit2.symbol):find('⋅', 1, true) then
paren1, paren2 = '(', ')'
end
end
local key_id2 -- unit2 is always singular
if key_id == 'name2' then
key_id2 = 'name1'
elseif key_id == 'name2_us' then
key_id2 = 'name1_us'
else
key_id2 = key_id
end
if key_id2 == 'name1' or key_id2 == 'name1_us' then
key_id2 = unit2.pername and 'pername' or key_id2 -- ukwiki has some units with a different name in "per unitname"
end
local result
if abbr_on then
result = '/'
elseif omitsep then
result = per_word
elseif unit1 then
result = ' ' .. per_word .. ' '
else
result = per_word .. ' '
end
if want_link and unit_table.link then
if varname and not abbr_on then
result = (unit1 and variable_name(clean, unit1, exp_multiplier) or '') .. result .. variable_name('1', unit2, exp_multiplier, key_id2)
else
result = (unit1 and linked_id(parms, unit1, key_id, false, clean) or '') .. result .. linked_id(parms, unit2, key_id2, false, '1')
end
if omit_separator(result) then
unit_table.sep = ''
end
return make_link(unit_table.link, result, unit_table)
end
if unit1 then
result = linked_id(parms, unit1, key_id, want_link, clean) .. result
if unit1.sep then
unit_table.sep = unit1.sep
end
elseif omitsep then
unit_table.sep = ''
end
return result .. paren1 .. linked_id(parms, unit2, key_id2, want_link, '1') .. paren2
end
if multiplier then
-- A multiplier (like "100" in "100km") forces the unit to be plural.
multiplier = from_en(multiplier)
if not omitsep then
multiplier = multiplier .. (abbr_on and ' ' or ' ')
end
if not abbr_on then
if key_id == 'name1' then
key_id = 'name2'
elseif key_id == 'name1_us' then
key_id = 'name2_us'
end
end
else
multiplier = ''
end
local id = unit_table.fixed_name or ((varname and not abbr_on) and variable_name(clean, unit_table, exp_multiplier, key_id) or unit_table[key_id])
if omit_separator(id) then
unit_table.sep = ''
end
if want_link then
local link = data_code.link_exceptions[unit_table.linkey or unit_table.symbol] or unit_table.link
if link then
local before = ''
local i = unit_table.customary
if i == 1 and parms.opt_sp_us then
i = 2 -- show "U.S." not "US"
end
if i == 3 and abbr_on then
i = 4 -- abbreviate "imperial" to "imp"
end
local customary = text_code.customary_units[i]
if customary then
-- LATER: This works for language en only, but it's esoteric so ignore for now.
local pertext
if id:sub(1, 1) == '/' then
-- Want unit "/USgal" to display as "/U.S. gal", not "U.S. /gal".
pertext = '/'
id = id:sub(2)
elseif id:sub(1, 4) == 'per ' then
-- Similarly want "per U.S. gallon", not "U.S. per gallon" (but in practice this is unlikely to be used).
pertext = 'per '
id = id:sub(5)
else
pertext = ''
end
-- Omit any "US"/"U.S."/"imp"/"imperial" from start of id since that will be inserted.
local removes = (i < 3) and { 'US ', 'US ', 'U.S. ', 'U.S. ' } or { 'imp ', 'imp ', 'imperial ' }
for _, prefix in ipairs(removes) do
local plen = #prefix
if id:sub(1, plen) == prefix then
id = id:sub(plen + 1)
break
end
end
before = pertext .. make_link(customary.link, customary[1]) .. ' '
end
id = before .. make_link(link, id, unit_table)
end
end
return multiplier .. id
end
local function make_id(parms, which, unit_table)
-- Return id, f where
-- id = unit name or symbol, possibly modified
-- f = true if id is a name, or false if id is a symbol
-- using the value for index 'which', and for 'in' or 'out' (unit_table.inout).
-- Result is '' if no symbol/name is to be used.
-- In addition, set unit_table.sep = ' ' or ' ' or ''
-- (the separator that caller will normally insert before the id).
if parms.opt_values then
unit_table.sep = ''
return ''
end
local inout = unit_table.inout
local info = unit_table.valinfo[which]
local lk = parms.lk
local want_link = (lk == 'on' or lk == inout)
local singular = info.singular
local want_name
local exp_multiplier
if unit_table.usename then
want_name = true
else
if parms.abbr_org == nil then
if parms.wantname then
want_name = true
end
if unit_table.usesymbol then
want_name = false
end
end
if want_name == nil then
local abbr = parms.abbr
if abbr == 'on' or abbr == inout or (abbr == 'mos' and inout == 'out') then
want_name = false
else
want_name = true
end
end
end
local key
if want_name then
if lk == nil and unit_table.builtin == 'hand' then
want_link = true
end
if parms.opt_use_nbsp then
unit_table.sep = ' '
else
unit_table.sep = ' '
end
if parms.opt_singular then
local value
if inout == 'in' then
value = info.value
else
value = info.absvalue
end
if value then -- some unusual units do not always set value field
value = abs(value)
singular = (0 < value and value < 1.0001)
end
end
if unit_table.engscale then
-- engscale: so "|1|e3kg" gives "1 thousand kilograms" (plural)
singular = false
exp_multiplier = 10^unit_table.engscale.exponent -- '1 gram' and '1 thousand grams', for example, may use different names for the unit in some languages
end
key = (parms.opt_adjectival or singular) and 'name1' or 'name2'
if parms.opt_sp_us then
key = key .. '_us'
end
else
if unit_table.builtin == 'hand' then
if parms.opt_hand_hh then
unit_table.symbol = 'hh' -- LATER: might want i18n applied to this
end
end
unit_table.sep = ' '
key = parms.opt_sp_us and 'sym_us' or 'symbol'
end
return linked_id(parms, unit_table, key, want_link, info.clean, exp_multiplier), want_name
end
local function decorate_value(parms, unit_table, which, enable_number_word)
-- If needed, update unit_table so values will be shown with extra information.
-- For consistency with the old template (but different from fmtpower),
-- the style to display powers of 10 includes "display:none" to allow some
-- browsers to copy, for example, "10³" as "10^3", rather than as "103".
-- The engscale table may have entries such as either of the following:
-- ["3"] = { "thousand", exponent = 3 },
-- ["3"] = { name1 = "A", varname = "B!C!D", exponent = 3 },
-- The first option always uses "thousand" as the exponent name.
-- The second option uses one of A, B, C, D as the exponent name, depending on the value.
local info
local engscale = unit_table.engscale
local prefix = unit_table.vprefix
if engscale or prefix then
info = unit_table.valinfo[which]
if info.decorated then
return -- do not redecorate if repeating convert
end
info.decorated = true
if engscale then
-- Range |10|-|20|e3km| gives '10×10³–20×10³' or '10–20 thousand'.
local inout = unit_table.inout
local abbr = parms.abbr
if (abbr == 'on' or abbr == inout) and not (unit_table.this_number_word or parms.number_word) then
info.show = info.show ..
'<span style="margin-left:0.2em">×<span style="margin-left:0.1em">' ..
from_en('10') ..
'</span></span><s style="display:none">^</s><sup>' ..
from_en(tostring(engscale.exponent)) .. '</sup>'
elseif enable_number_word then
local number_id
local name = engscale.varname and variable_name(info.clean, engscale) or engscale[1]
if parms.lk == 'on' or parms.lk == inout then
number_id = make_link(engscale.link, name)
else
number_id = name
end
-- WP:NUMERAL recommends " " in values like "12 million".
info.show = info.show .. (parms.opt_adjectival and '-' or ' ') .. number_id
end
end
if prefix then
info.show = prefix .. info.show
end
end
end
local function process_input(parms, in_current)
-- Processing required once per conversion.
-- Return block of text to represent input (value/unit).
if parms.opt_output_only or parms.opt_output_number_only or parms.opt_output_unit_only then
parms.joins = { '', '' }
return ''
end
local first_unit
local composite = in_current.composite -- nil or table of units
if composite then
first_unit = composite[1]
else
first_unit = in_current
end
local id1, want_name = make_id(parms, 1, first_unit)
local sep = first_unit.sep -- separator between value and unit, set by make_id
local preunit = parms.preunit1
if preunit then
sep = '' -- any separator is included in preunit
else
preunit = ''
end
if parms.opt_input_unit_only then
parms.joins = { '', '' }
if composite then
local parts = { id1 }
for i, unit in ipairs(composite) do
if i > 1 then
table.insert(parts, (make_id(parms, 1, unit)))
end
end
id1 = table.concat(parts, ' ')
end
if want_name and parms.opt_adjectival then
return preunit .. hyphenated(id1)
end
return preunit .. id1
end
if parms.opt_also_symbol and not composite and not parms.opt_flip then
local join1 = parms.joins[1]
if join1 == ' (' or join1 == ' [' then
parms.joins = { ' [' .. first_unit[parms.opt_sp_us and 'sym_us' or 'symbol'] .. ']' .. join1 , parms.joins[2] }
end
end
if in_current.builtin == 'mach' and first_unit.sep ~= '' then -- '' means omitsep with non-enwiki name
local prefix = id1 .. ' '
local range = parms.range
local valinfo = first_unit.valinfo
local result = prefix .. valinfo[1].show
if range then
-- For simplicity and because more not needed, handle one range item only.
local prefix2 = make_id(parms, 2, first_unit) .. ' '
result = range_text(range[1], want_name, parms, result, prefix2 .. valinfo[2].show, 'in', {spaced=true})
end
return preunit .. result
end
if composite then
-- Simplify: assume there is no range, and no decoration.
local mid = (not parms.opt_flip) and parms.mid or ''
local sep1 = ' '
local sep2 = ' '
if parms.opt_adjectival and want_name then
sep1 = '-'
sep2 = '-'
end
if omitsep and sep == '' then
-- Testing the id of the most significant unit should be sufficient.
sep1 = ''
sep2 = ''
end
local parts = { first_unit.valinfo[1].show .. sep1 .. id1 }
for i, unit in ipairs(composite) do
if i > 1 then
table.insert(parts, unit.valinfo[1].show .. sep1 .. (make_id(parms, 1, unit)))
end
end
return table.concat(parts, sep2) .. mid
end
local add_unit = (parms.abbr == 'mos') or
parms[parms.opt_flip and 'out_range_x' or 'in_range_x'] or
(not want_name and parms.abbr_range_x)
local range = parms.range
if range and not add_unit then
unlink(first_unit)
end
local id = range and make_id(parms, range.n + 1, first_unit) or id1
local extra, was_hyphenated = hyphenated_maybe(parms, want_name, sep, id, 'in')
if was_hyphenated then
add_unit = false
end
local result
local valinfo = first_unit.valinfo
if range then
for i = 0, range.n do
local enable_number_word
if i == range.n then
add_unit = false
enable_number_word = true
end
decorate_value(parms, first_unit, i+1, enable_number_word)
local show = valinfo[i+1].show
if add_unit then
show = show .. first_unit.sep .. (i == 0 and id1 or make_id(parms, i+1, first_unit))
end
if i == 0 then
result = show
else
result = range_text(range[i], want_name, parms, result, show, 'in')
end
end
else
decorate_value(parms, first_unit, 1, true)
result = valinfo[1].show
end
return result .. preunit .. extra
end
local function process_one_output(parms, out_current)
-- Processing required for each output unit.
-- Return block of text to represent output (value/unit).
local inout = out_current.inout -- normally 'out' but can be 'in' for order=out
local id1, want_name = make_id(parms, 1, out_current)
local sep = out_current.sep -- set by make_id
local preunit = parms.preunit2
if preunit then
sep = '' -- any separator is included in preunit
else
preunit = ''
end
if parms.opt_output_unit_only then
if want_name and parms.opt_adjectival then
return preunit .. hyphenated(id1)
end
return preunit .. id1
end
if out_current.builtin == 'mach' and out_current.sep ~= '' then -- '' means omitsep with non-enwiki name
local prefix = id1 .. ' '
local range = parms.range
local valinfo = out_current.valinfo
local result = prefix .. valinfo[1].show
if range then
-- For simplicity and because more not needed, handle one range item only.
result = range_text(range[1], want_name, parms, result, prefix .. valinfo[2].show, inout, {spaced=true})
end
return preunit .. result
end
local add_unit = (parms[parms.opt_flip and 'in_range_x' or 'out_range_x'] or
(not want_name and parms.abbr_range_x)) and
not parms.opt_output_number_only
local range = parms.range
if range and not add_unit then
unlink(out_current)
end
local id = range and make_id(parms, range.n + 1, out_current) or id1
local extra, was_hyphenated = hyphenated_maybe(parms, want_name, sep, id, inout)
if was_hyphenated then
add_unit = false
end
local result
local valinfo = out_current.valinfo
if range then
for i = 0, range.n do
local enable_number_word
if i == range.n then
add_unit = false
enable_number_word = true
end
decorate_value(parms, out_current, i+1, enable_number_word)
local show = valinfo[i+1].show
if add_unit then
show = show .. out_current.sep .. (i == 0 and id1 or make_id(parms, i+1, out_current))
end
if i == 0 then
result = show
else
result = range_text(range[i], want_name, parms, result, show, inout)
end
end
else
decorate_value(parms, out_current, 1, true)
result = valinfo[1].show
end
if parms.opt_output_number_only then
return result
end
return result .. preunit .. extra
end
local function make_output_single(parms, in_unit_table, out_unit_table)
-- Return true, item where item = wikitext of the conversion result
-- for a single output (which is not a combination or a multiple);
-- or return false, t where t is an error message table.
if parms.opt_order_out and in_unit_table.unitcode == out_unit_table.unitcode then
out_unit_table.valinfo = in_unit_table.valinfo
else
out_unit_table.valinfo = collection()
for _, v in ipairs(in_unit_table.valinfo) do
local success, info = cvtround(parms, v, in_unit_table, out_unit_table)
if not success then return false, info end
out_unit_table.valinfo:add(info)
end
end
return true, process_one_output(parms, out_unit_table)
end
local function make_output_multiple(parms, in_unit_table, out_unit_table)
-- Return true, item where item = wikitext of the conversion result
-- for an output which is a multiple (like 'ftin');
-- or return false, t where t is an error message table.
local inout = out_unit_table.inout -- normally 'out' but can be 'in' for order=out
local multiple = out_unit_table.multiple -- table of scaling factors (will not be nil)
local combos = out_unit_table.combination -- table of unit tables (will not be nil)
local abbr = parms.abbr
local abbr_org = parms.abbr_org
local disp = parms.disp
local want_name = (abbr_org == nil and (disp == 'or' or disp == 'slash')) or
not (abbr == 'on' or abbr == inout or abbr == 'mos')
local want_link = (parms.lk == 'on' or parms.lk == inout)
local mid = parms.opt_flip and parms.mid or ''
local sep1 = ' '
local sep2 = ' '
if parms.opt_adjectival and want_name then
sep1 = '-'
sep2 = '-'
end
local do_spell = parms.opt_spell_out
parms.opt_spell_out = nil -- so the call to cvtround does not spell the value
local function make_result(info, isfirst)
local fmt, outvalue, sign
local results = {}
for i = 1, #combos do
local tfrac, thisvalue, strforce
local out_current = combos[i]
out_current.inout = inout
local scale = multiple[i]
if i == 1 then -- least significant unit ('in' from 'ftin')
local decimals
out_current.frac = out_unit_table.frac
local success, outinfo = cvtround(parms, info, in_unit_table, out_current)
if not success then return false, outinfo end
if isfirst then
out_unit_table.valinfo = { outinfo } -- in case output value of first least significant unit is needed
end
sign = outinfo.sign
tfrac = outinfo.fraction_table
if outinfo.is_scientific then
strforce = outinfo.show
decimals = ''
elseif tfrac then
decimals = ''
else
local show = outinfo.show -- number as a string in local language
local p1, p2 = show:find(numdot, 1, true)
decimals = p1 and show:sub(p2 + 1) or '' -- text after numdot, if any
end
fmt = '%.' .. ulen(decimals) .. 'f' -- to reproduce precision
if decimals == '' then
if tfrac then
outvalue = floor(outinfo.raw_absvalue) -- integer part only; fraction added later
else
outvalue = floor(outinfo.raw_absvalue + 0.5) -- keep all integer digits of least significant unit
end
else
outvalue = outinfo.absvalue
end
end
if scale then
outvalue, thisvalue = divide(outvalue, scale)
else
thisvalue = outvalue
end
local id
if want_name then
if varname then
local clean
if strforce or tfrac then
clean = '.1' -- dummy value to force name for floating point
else
clean = format(fmt, thisvalue)
end
id = variable_name(clean, out_current)
else
local key = 'name2'
if parms.opt_adjectival then
key = 'name1'
elseif tfrac then
if thisvalue == 0 then
key = 'name1'
end
elseif parms.opt_singular then
if 0 < thisvalue and thisvalue < 1.0001 then
key = 'name1'
end
else
if thisvalue == 1 then
key = 'name1'
end
end
id = out_current[key]
end
else
id = out_current['symbol']
end
if i == 1 and omit_separator(id) then
-- Testing the id of the least significant unit should be sufficient.
sep1 = ''
sep2 = ''
end
if want_link then
local link = out_current.link
if link then
id = make_link(link, id, out_current)
end
end
local strval
local spell_inout = (i == #combos or outvalue == 0) and inout or '' -- trick so the last value processed (first displayed) has uppercase, if requested
if strforce and outvalue == 0 then
sign = '' -- any sign is in strforce
strval = strforce -- show small values in scientific notation; will only use least significant unit
elseif tfrac then
local wholestr = (thisvalue > 0) and tostring(thisvalue) or nil
strval = format_fraction(parms, spell_inout, false, wholestr, tfrac.numstr, tfrac.denstr, do_spell)
else
strval = (thisvalue == 0) and from_en('0') or with_separator(parms, format(fmt, thisvalue))
if do_spell then
strval = spell_number(parms, spell_inout, strval) or strval
end
end
table.insert(results, strval .. sep1 .. id)
if outvalue == 0 then
break
end
fmt = '%.0f' -- only least significant unit can have a non-integral value
end
local reversed, count = {}, #results
for i = 1, count do
reversed[i] = results[count + 1 - i]
end
return true, sign .. table.concat(reversed, sep2)
end
local valinfo = in_unit_table.valinfo
local success, result = make_result(valinfo[1], true)
if not success then return false, result end
local range = parms.range
if range then
for i = 1, range.n do
local success, result2 = make_result(valinfo[i+1])
if not success then return false, result2 end
result = range_text(range[i], want_name, parms, result, result2, inout, {spaced=true})
end
end
return true, result .. mid
end
local function process(parms, in_unit_table, out_unit_table)
-- Return true, s, outunit where s = final wikitext result,
-- or return false, t where t is an error message table.
linked_pages = {}
local success, bad_output
local bad_input_mcode = in_unit_table.bad_mcode -- nil if input unit is a valid convert unit
local out_unit = parms.out_unit
if out_unit == nil or out_unit == '' or type(out_unit) == 'function' then
-- out_unit can be set to a function by adjustparameters in Module:Convert/wikidata.
if bad_input_mcode or parms.opt_input_unit_only then
bad_output = ''
else
local getdef = type(out_unit) == 'function' and out_unit or get_default
success, out_unit = getdef(in_unit_table.valinfo[1].value, in_unit_table)
parms.out_unit = out_unit
if not success then
bad_output = out_unit
end
end
end
if not bad_output and not out_unit_table then
success, out_unit_table = lookup(parms, out_unit, 'any_combination')
if success then
local mismatch = check_mismatch(in_unit_table, out_unit_table)
if mismatch then
bad_output = mismatch
end
else
bad_output = out_unit_table
end
end
local lhs, rhs
local flipped = parms.opt_flip and not bad_input_mcode
if bad_output then
rhs = (bad_output == '') and '' or message(parms, bad_output)
elseif parms.opt_input_unit_only then
rhs = ''
else
local combos -- nil (for 'ft' or 'ftin'), or table of unit tables (for 'm ft')
if not out_unit_table.multiple then -- nil/false ('ft' or 'm ft'), or table of factors ('ftin')
combos = out_unit_table.combination
end
local frac = parms.frac -- nil or denominator of fraction for output values
if frac then
-- Apply fraction to the unit (if only one), or to non-SI units (if a combination),
-- except that if a precision is also specified, the fraction only applies to
-- the hand unit; that allows the following result:
-- {{convert|156|cm|in hand|1|frac=2}} → 156 centimetres (61.4 in; 15.1½ hands)
-- However, the following is handled elsewhere as a special case:
-- {{convert|156|cm|hand in|1|frac=2}} → 156 centimetres (15.1½ hands; 61½ in)
if combos then
local precision = parms.precision
for _, unit in ipairs(combos) do
if unit.builtin == 'hand' or (not precision and not unit.prefixes) then
unit.frac = frac
end
end
else
out_unit_table.frac = frac
end
end
local outputs = {}
local imax = combos and #combos or 1 -- 1 (single unit) or number of unit tables
if imax == 1 then
parms.opt_order_out = nil -- only useful with an output combination
end
if not flipped and not parms.opt_order_out then
-- Process left side first so any duplicate links (from lk=on) are suppressed
-- on right. Example: {{convert|28|e9pc|e9ly|abbr=off|lk=on}}
lhs = process_input(parms, in_unit_table)
end
for i = 1, imax do
local success, item
local out_current = combos and combos[i] or out_unit_table
out_current.inout = 'out'
if i == 1 then
if imax > 1 and out_current.builtin == 'hand' then
out_current.out_next = combos[2] -- built-in hand can influence next unit in a combination
end
if parms.opt_order_out then
out_current.inout = 'in'
end
end
if out_current.multiple then
success, item = make_output_multiple(parms, in_unit_table, out_current)
else
success, item = make_output_single(parms, in_unit_table, out_current)
end
if not success then return false, item end
outputs[i] = item
end
if parms.opt_order_out then
lhs = outputs[1]
table.remove(outputs, 1)
end
local sep = parms.table_joins and parms.table_joins[2] or parms.join_between
rhs = table.concat(outputs, sep)
end
if flipped or not lhs then
local input = process_input(parms, in_unit_table)
if flipped then
lhs = rhs
rhs = input
else
lhs = input
end
end
if parms.join_before then
lhs = parms.join_before .. lhs
end
local wikitext
if bad_input_mcode then
if bad_input_mcode == '' then
wikitext = lhs
else
wikitext = lhs .. message(parms, bad_input_mcode)
end
elseif parms.table_joins then
wikitext = parms.table_joins[1] .. lhs .. parms.table_joins[2] .. rhs
else
wikitext = lhs .. parms.joins[1] .. rhs .. parms.joins[2]
end
if parms.warnings and not bad_input_mcode then
wikitext = wikitext .. parms.warnings
end
return true, get_styles(parms) .. wikitext, out_unit_table
end
local function _main_convert(confArgs, parmsArgs, frame)
-- Do convert, and if needed, do it again with higher default precision.
local parms = { frame = frame or mw.getCurrentFrame() } -- will hold template arguments, after translation
set_config(confArgs)
local success, result = get_parms(parms, parmsArgs)
if success then
if type(result) ~= 'table' then
return tostring(result)
end
local in_unit_table = result
local out_unit_table
for _ = 1, 2 do -- use counter so cannot get stuck repeating convert
success, result, out_unit_table = process(parms, in_unit_table, out_unit_table)
if success and parms.do_convert_again then
parms.do_convert_again = false
else
break
end
end
end
-- If input=x gives a problem, the result should be just the user input
-- (if x is a property like P123 it has been replaced with '').
-- An unknown input unit would display the input and an error message
-- with success == true at this point.
-- Also, can have success == false with a message that outputs an empty string.
if parms.input_text then
if success and not parms.have_problem then
return result
end
local cat
if parms.tracking then
-- Add a tracking category using the given text as the category sort key.
-- There is currently only one type of tracking, but in principle multiple
-- items could be tracked, using different sort keys for convenience.
cat = wanted_category('tracking', parms.tracking)
end
return parms.input_text .. (cat or '')
end
return success and result or message(parms, result)
end
local function main_convert(frame)
return _main_convert(frame.args, frame:getParent().args, frame)
end
local function _unit(unitcode, options)
-- Helper function for Module:Val to look up a unit.
-- Parameter unitcode must be a string to identify the wanted unit.
-- Parameter options must be nil or a table with optional fields:
-- value = number (for sort key; default value is 1)
-- scaled_top = nil for a normal unit, or a number for a unit which is
-- the denominator of a per unit (for sort key)
-- si = { 'symbol', 'link' }
-- (a table with two strings) to make an SI unit
-- that will be used for the look up
-- link = true if result should be [[linked]]
-- sort = 'on' or 'debug' if result should include a sort key in a
-- span element ('debug' makes the key visible)
-- name = true for the name of the unit instead of the symbol
-- us = true for the US spelling of the unit, if any
-- Return nil if unitcode is not a non-empty string.
-- Otherwise return a table with fields:
-- text = requested symbol or name of unit, optionally linked
-- scaled_value = input value adjusted by unit scale; used for sort key
-- sortspan = span element with sort key like that provided by {{ntsh}},
-- calculated from the result of converting value
-- to a base unit with scale 1.
-- unknown = true if the unitcode was not known
unitcode = strip(unitcode)
if unitcode == nil or unitcode == '' then
return nil
end
set_config({})
linked_pages = {}
options = options or {}
local parms = {
abbr = options.name and 'off' or 'on',
lk = options.link and 'on' or nil,
opt_sp_us = options.us and true or nil,
opt_ignore_error = true, -- do not add pages using this function to 'what links here' for Module:Convert/extra
opt_sortable_on = options.sort == 'on' or options.sort == 'debug',
opt_sortable_debug = options.sort == 'debug',
}
if options.si then
-- Make a dummy table of units (just one unit) for lookup to use.
-- This makes lookup recognize any SI prefix in the unitcode.
local symbol = options.si[1] or '?'
parms.unittable = { [symbol] = {
_name1 = symbol,
_name2 = symbol,
_symbol = symbol,
utype = symbol,
scale = symbol == 'g' and 0.001 or 1,
prefixes = 1,
default = symbol,
link = options.si[2],
}}
end
local success, unit_table = lookup(parms, unitcode, 'no_combination')
if not success then
unit_table = setmetatable({
symbol = unitcode, name2 = unitcode, utype = unitcode,
scale = 1, default = '', defkey = '', linkey = '' }, unit_mt)
end
local value = tonumber(options.value) or 1
local clean = tostring(abs(value))
local info = {
value = value,
altvalue = value,
singular = (clean == '1'),
clean = clean,
show = clean,
}
unit_table.inout = 'in'
unit_table.valinfo = { info }
local sortspan, scaled_value
if options.sort then
sortspan, scaled_value = make_table_or_sort(parms, value, info, unit_table, options.scaled_top)
end
return {
text = make_id(parms, 1, unit_table),
sortspan = sortspan,
scaled_value = scaled_value,
unknown = not success and true or nil,
}
end
return { convert = main_convert, _convert = _main_convert, _unit = _unit }
84ef1800df9ddbc24da3d295d74282d1c59ec2b5
Module:Convert/data
828
721
1106
1105
2025-08-22T00:55:51Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Conversion data used by [[Module:Convert]] which uses mw.loadData() for
-- read-only access to this module so that it is loaded only once per page.
-- See [[:en:Template:Convert/Transwiki guide]] if copying to another wiki.
--
-- These data tables follow:
-- all_units all properties for a unit, including default output
-- default_exceptions exceptions for default output ('kg' and 'g' have different defaults)
-- link_exceptions exceptions for links ('kg' and 'g' have different links)
--
-- These tables are generated by a script which reads the wikitext of a page that
-- documents the required properties of each unit; see [[:en:Module:Convert/doc]].
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local all_units = {
["Gy"] = {
_name1 = "gray",
_symbol = "Gy",
utype = "absorbed radiation dose",
scale = 1,
prefixes = 1,
default = "rad",
link = "Gray (unit)",
},
["rad"] = {
_name1 = "rad",
_symbol = "rad",
utype = "absorbed radiation dose",
scale = 0.01,
prefixes = 1,
default = "Gy",
link = "Rad (unit)",
},
["cm/s2"] = {
name1 = "centimetre per second squared",
name1_us = "centimeter per second squared",
name2 = "centimetres per second squared",
name2_us = "centimeters per second squared",
symbol = "cm/s<sup>2</sup>",
utype = "acceleration",
scale = 0.01,
default = "ft/s2",
link = "Gal (unit)",
},
["ft/s2"] = {
name1 = "foot per second squared",
name2 = "feet per second squared",
symbol = "ft/s<sup>2</sup>",
utype = "acceleration",
scale = 0.3048,
default = "m/s2",
},
["g0"] = {
name1 = "standard gravity",
name2 = "standard gravities",
symbol = "''g''<sub>0</sub>",
utype = "acceleration",
scale = 9.80665,
default = "m/s2",
},
["g-force"] = {
name2 = "''g''",
symbol = "''g''",
utype = "acceleration",
scale = 9.80665,
default = "m/s2",
link = "g-force",
},
["km/hs"] = {
name1 = "kilometre per hour per second",
name1_us = "kilometer per hour per second",
name2 = "kilometres per hour per second",
name2_us = "kilometers per hour per second",
symbol = "km/(h⋅s)",
utype = "acceleration",
scale = 0.27777777777777779,
default = "mph/s",
link = "Acceleration",
},
["km/s2"] = {
name1 = "kilometre per second squared",
name1_us = "kilometer per second squared",
name2 = "kilometres per second squared",
name2_us = "kilometers per second squared",
symbol = "km/s<sup>2</sup>",
utype = "acceleration",
scale = 1000,
default = "mph/s",
link = "Acceleration",
},
["m/s2"] = {
name1 = "metre per second squared",
name1_us = "meter per second squared",
name2 = "metres per second squared",
name2_us = "meters per second squared",
symbol = "m/s<sup>2</sup>",
utype = "acceleration",
scale = 1,
default = "ft/s2",
},
["mph/s"] = {
name1 = "mile per hour per second",
name2 = "miles per hour per second",
symbol = "mph/s",
utype = "acceleration",
scale = 0.44704,
default = "km/hs",
link = "Acceleration",
},
["km/h/s"] = {
target = "km/hs",
},
["standard gravity"] = {
target = "g0",
},
["1000sqft"] = {
name1 = "thousand square feet",
name2 = "thousand square feet",
symbol = "1000 sq ft",
utype = "area",
scale = 92.90304,
default = "m2",
link = "Square foot",
},
["a"] = {
_name1 = "are",
_symbol = "a",
utype = "area",
scale = 100,
prefixes = 1,
default = "sqft",
link = "Hectare#Are",
},
["acre"] = {
symbol = "acre",
usename = 1,
utype = "area",
scale = 4046.8564224,
default = "ha",
subdivs = { ["rood"] = { 4, default = "ha" }, ["sqperch"] = { 160, default = "ha" } },
},
["acre-sing"] = {
target = "acre",
},
["arpent"] = {
symbol = "arpent",
usename = 1,
utype = "area",
scale = 3418.89,
default = "ha",
},
["cda"] = {
name1 = "cuerda",
symbol = "cda",
utype = "area",
scale = 3930.395625,
default = "ha acre",
},
["daa"] = {
name1 = "decare",
symbol = "daa",
utype = "area",
scale = 1000,
default = "km2 sqmi",
},
["dunam"] = {
symbol = "dunam",
usename = 1,
utype = "area",
scale = 1000,
default = "km2 sqmi",
},
["dunum"] = {
symbol = "dunum",
usename = 1,
utype = "area",
scale = 1000,
default = "km2 sqmi",
link = "Dunam",
},
["ha"] = {
name1 = "hectare",
symbol = "ha",
utype = "area",
scale = 10000,
default = "acre",
},
["hectare"] = {
name1 = "hectare",
symbol = "ha",
usename = 1,
utype = "area",
scale = 10000,
default = "acre",
},
["Irish acre"] = {
name1 = "Irish acre",
symbol = "Irish acres",
utype = "area",
scale = 6555.2385024,
default = "ha",
link = "Acre (Irish)",
},
["m2"] = {
_name1 = "square metre",
_name1_us= "square meter",
_symbol = "m<sup>2</sup>",
prefix_position= 8,
utype = "area",
scale = 1,
prefixes = 2,
default = "sqft",
link = "Square metre",
},
["pondemaat"] = {
name1 = "pondemaat",
name2 = "pondemaat",
symbol = "pond",
utype = "area",
scale = 3674.363358816,
default = "m2",
link = ":nl:pondemaat",
},
["pyeong"] = {
name2 = "pyeong",
symbol = "pyeong",
usename = 1,
utype = "area",
scale = 3.3057851239669422,
default = "m2",
},
["rai"] = {
name2 = "rai",
symbol = "rai",
utype = "area",
scale = 1600,
default = "m2",
link = "Rai (unit)",
},
["rood"] = {
symbol = "rood",
usename = 1,
utype = "area",
scale = 1011.7141056,
default = "sqft m2",
subdivs = { ["sqperch"] = { 40, default = "m2" } },
link = "Rood (unit)",
},
["sqfoot"] = {
name1 = "square foot",
name2 = "square foot",
symbol = "sq ft",
utype = "area",
scale = 0.09290304,
default = "m2",
},
["sqft"] = {
name1 = "square foot",
name2 = "square feet",
symbol = "sq ft",
utype = "area",
scale = 0.09290304,
default = "m2",
},
["sqin"] = {
name1 = "square inch",
name2 = "square inches",
symbol = "sq in",
utype = "area",
scale = 0.00064516,
default = "cm2",
},
["sqmi"] = {
name1 = "square mile",
symbol = "sq mi",
utype = "area",
scale = 2589988.110336,
default = "km2",
},
["sqnmi"] = {
name1 = "square nautical mile",
symbol = "sq nmi",
utype = "area",
scale = 3429904,
default = "km2 sqmi",
link = "Nautical mile",
},
["sqperch"] = {
name2 = "perches",
symbol = "perch",
usename = 1,
utype = "area",
scale = 25.29285264,
default = "m2",
link = "Rod (unit)#Area and volume",
},
["sqverst"] = {
symbol = "square verst",
usename = 1,
utype = "area",
scale = 1138062.24,
default = "km2 sqmi",
link = "Verst",
},
["sqyd"] = {
name1 = "square yard",
symbol = "sq yd",
utype = "area",
scale = 0.83612736,
default = "m2",
},
["tsubo"] = {
name2 = "tsubo",
symbol = "tsubo",
usename = 1,
utype = "area",
scale = 3.3057851239669422,
default = "m2",
link = "Japanese units of measurement#Area",
},
["acres"] = {
target = "acre",
},
["are"] = {
target = "a",
},
["decare"] = {
target = "daa",
},
["foot2"] = {
target = "sqfoot",
},
["ft2"] = {
target = "sqft",
},
["in2"] = {
target = "sqin",
symbol = "in<sup>2</sup>",
},
["km²"] = {
target = "km2",
},
["mi2"] = {
target = "sqmi",
},
["million acre"] = {
target = "e6acre",
},
["million acres"] = {
target = "e6acre",
},
["million hectares"] = {
target = "e6ha",
},
["m²"] = {
target = "m2",
},
["nmi2"] = {
target = "sqnmi",
},
["pond"] = {
target = "pondemaat",
},
["sq arp"] = {
target = "arpent",
},
["sqkm"] = {
target = "km2",
},
["sqm"] = {
target = "m2",
},
["square verst"] = {
target = "sqverst",
},
["verst2"] = {
target = "sqverst",
},
["yd2"] = {
target = "sqyd",
},
["m2/ha"] = {
name1 = "square metre per hectare",
name1_us = "square meter per hectare",
name2 = "square metres per hectare",
name2_us = "square meters per hectare",
symbol = "m<sup>2</sup>/ha",
utype = "area per unit area",
scale = 0.0001,
default = "sqft/acre",
link = "Basal area",
},
["sqft/acre"] = {
name1 = "square foot per acre",
name2 = "square feet per acre",
symbol = "sq ft/acre",
utype = "area per unit area",
scale = 2.295684113865932e-5,
default = "m2/ha",
link = "Basal area",
},
["cent"] = {
name1 = "cent",
symbol = "¢",
utype = "cent",
scale = 1,
default = "cent",
link = "Cent (currency)",
},
["¢"] = {
target = "cent",
},
["A.h"] = {
name1 = "ampere hour",
symbol = "A⋅h",
utype = "charge",
scale = 3600,
default = "coulomb",
},
["coulomb"] = {
_name1 = "coulomb",
_symbol = "C",
utype = "charge",
scale = 1,
prefixes = 1,
default = "e",
link = "Coulomb",
},
["e"] = {
name1 = "elementary charge",
symbol = "''e''",
utype = "charge",
scale = 1.602176487e-19,
default = "coulomb",
},
["g-mol"] = {
name1 = "gram-mole",
symbol = "g‑mol",
utype = "chemical amount",
scale = 1,
default = "lbmol",
link = "Mole (unit)",
},
["gmol"] = {
name1 = "gram-mole",
symbol = "gmol",
utype = "chemical amount",
scale = 1,
default = "lbmol",
link = "Mole (unit)",
},
["kmol"] = {
name1 = "kilomole",
symbol = "kmol",
utype = "chemical amount",
scale = 1000,
default = "lbmol",
link = "Mole (unit)",
},
["lb-mol"] = {
name1 = "pound-mole",
symbol = "lb‑mol",
utype = "chemical amount",
scale = 453.59237,
default = "mol",
},
["lbmol"] = {
name1 = "pound-mole",
symbol = "lbmol",
utype = "chemical amount",
scale = 453.59237,
default = "mol",
},
["mol"] = {
name1 = "mole",
symbol = "mol",
utype = "chemical amount",
scale = 1,
default = "lbmol",
link = "Mole (unit)",
},
["kgCO2/L"] = {
name1 = "kilogram per litre",
name1_us = "kilogram per liter",
name2 = "kilograms per litre",
name2_us = "kilograms per liter",
symbol = "kg(CO<sub>2</sub>)/L",
utype = "co2 per unit volume",
scale = 1000,
default = "lbCO2/USgal",
link = "Exhaust gas",
},
["lbCO2/USgal"] = {
name1 = "pound per US gallon",
name2 = "pounds per US gallon",
symbol = "lbCO2/US gal",
utype = "co2 per unit volume",
scale = 119.82642731689663,
default = "kgCO2/L",
link = "Exhaust gas",
},
["oz/lb"] = {
per = { "oz", "lb" },
utype = "concentration",
default = "mg/kg",
},
["mg/kg"] = {
per = { "mg", "kg" },
utype = "concentration",
default = "oz/lb",
},
["g/dm3"] = {
name1 = "gram per cubic decimetre",
name1_us = "gram per cubic decimeter",
name2 = "grams per cubic decimetre",
name2_us = "grams per cubic decimeter",
symbol = "g/dm<sup>3</sup>",
utype = "density",
scale = 1,
default = "kg/m3",
link = "Density",
},
["g/L"] = {
name1 = "gram per litre",
name1_us = "gram per liter",
name2 = "grams per litre",
name2_us = "grams per liter",
symbol = "g/L",
utype = "density",
scale = 1,
default = "lb/cuin",
link = "Density",
},
["g/mL"] = {
name1 = "gram per millilitre",
name1_us = "gram per milliliter",
name2 = "grams per millilitre",
name2_us = "grams per milliliter",
symbol = "g/mL",
utype = "density",
scale = 1000,
default = "lb/cuin",
link = "Density",
},
["g/ml"] = {
name1 = "gram per millilitre",
name1_us = "gram per milliliter",
name2 = "grams per millilitre",
name2_us = "grams per milliliter",
symbol = "g/ml",
utype = "density",
scale = 1000,
default = "lb/cuin",
link = "Density",
},
["kg/dm3"] = {
name1 = "kilogram per cubic decimetre",
name1_us = "kilogram per cubic decimeter",
name2 = "kilograms per cubic decimetre",
name2_us = "kilograms per cubic decimeter",
symbol = "kg/dm<sup>3</sup>",
utype = "density",
scale = 1000,
default = "lb/cuft",
link = "Density",
},
["kg/L"] = {
name1 = "kilogram per litre",
name1_us = "kilogram per liter",
name2 = "kilograms per litre",
name2_us = "kilograms per liter",
symbol = "kg/L",
utype = "density",
scale = 1000,
default = "lb/USgal",
link = "Density",
},
["kg/l"] = {
name1 = "kilogram per litre",
name1_us = "kilogram per liter",
name2 = "kilograms per litre",
name2_us = "kilograms per liter",
symbol = "kg/l",
utype = "density",
scale = 1000,
default = "lb/USgal",
link = "Density",
},
["kg/m3"] = {
name1 = "kilogram per cubic metre",
name1_us = "kilogram per cubic meter",
name2 = "kilograms per cubic metre",
name2_us = "kilograms per cubic meter",
symbol = "kg/m<sup>3</sup>",
utype = "density",
scale = 1,
default = "lb/cuyd",
link = "Density",
},
["lb/cuft"] = {
name1 = "pound per cubic foot",
name2 = "pounds per cubic foot",
symbol = "lb/cu ft",
utype = "density",
scale = 16.018463373960142,
default = "g/cm3",
link = "Density",
},
["lb/cuin"] = {
name1 = "pound per cubic inch",
name2 = "pounds per cubic inch",
symbol = "lb/cu in",
utype = "density",
scale = 27679.904710203122,
default = "g/cm3",
link = "Density",
},
["lb/cuyd"] = {
name1 = "pound per cubic yard",
name2 = "pounds per cubic yard",
symbol = "lb/cu yd",
utype = "density",
scale = 0.5932764212577829,
default = "kg/m3",
link = "Density",
},
["lb/impgal"] = {
name1 = "pound per imperial gallon",
name2 = "pounds per imperial gallon",
symbol = "lb/imp gal",
utype = "density",
scale = 99.776372663101697,
default = "kg/L",
link = "Density",
},
["lb/in3"] = {
name1 = "pound per cubic inch",
name2 = "pounds per cubic inch",
symbol = "lb/cu in",
utype = "density",
scale = 27679.904710203122,
default = "g/cm3",
link = "Density",
},
["lb/U.S.gal"] = {
name1 = "pound per U.S. gallon",
name2 = "pounds per U.S. gallon",
symbol = "lb/U.S. gal",
utype = "density",
scale = 119.82642731689663,
default = "kg/L",
link = "Density",
},
["lb/USbu"] = {
name1 = "pound per US bushel",
name2 = "pounds per US bushel",
symbol = "lb/US bu",
utype = "density",
scale = 12.871859780974471,
default = "kg/m3",
link = "Bushel",
},
["lb/USgal"] = {
name1 = "pound per US gallon",
name2 = "pounds per US gallon",
symbol = "lb/US gal",
utype = "density",
scale = 119.82642731689663,
default = "kg/L",
link = "Density",
},
["lbm/cuin"] = {
name1 = "pound mass per cubic inch",
name2 = "pounds mass per cubic inch",
symbol = "lbm/cu in",
utype = "density",
scale = 27679.904710203122,
default = "g/cm3",
link = "Density",
},
["mg/L"] = {
name1 = "milligram per litre",
name1_us = "milligram per liter",
name2 = "milligrams per litre",
name2_us = "milligrams per liter",
symbol = "mg/L",
utype = "density",
scale = 0.001,
default = "lb/cuin",
link = "Density",
},
["oz/cuin"] = {
name1 = "ounce per cubic inch",
name2 = "ounces per cubic inch",
symbol = "oz/cu in",
utype = "density",
scale = 1729.9940443876951,
default = "g/cm3",
link = "Density",
},
["g/cm3"] = {
per = { "g", "cm3" },
utype = "density",
default = "lb/cuin",
},
["g/m3"] = {
per = { "g", "m3" },
utype = "density",
default = "lb/cuyd",
link = "Density",
},
["Mg/m3"] = {
per = { "Mg", "m3" },
utype = "density",
default = "lb/cuft",
},
["mg/l"] = {
per = { "mg", "ll" },
utype = "density",
default = "oz/cuin",
},
["μg/dL"] = {
per = { "μg", "dL" },
utype = "density",
default = "lb/cuin",
},
["μg/l"] = {
per = { "μg", "ll" },
utype = "density",
default = "oz/cuin",
},
["lb/ft3"] = {
target = "lb/cuft",
},
["lb/yd3"] = {
target = "lb/cuyd",
},
["lbm/in3"] = {
target = "lbm/cuin",
},
["mcg/dL"] = {
target = "μg/dL",
},
["oz/in3"] = {
target = "oz/cuin",
},
["ug/dL"] = {
target = "μg/dL",
},
["ug/l"] = {
target = "μg/l",
},
["B.O.T.U."] = {
name1 = "Board of Trade Unit",
symbol = "B.O.T.U.",
utype = "energy",
scale = 3600000,
default = "MJ",
link = "Kilowatt-hour",
},
["bboe"] = {
name1 = "barrel of oil equivalent",
name2 = "barrels of oil equivalent",
symbol = "bboe",
utype = "energy",
scale = 6117863200,
default = "GJ",
},
["BOE"] = {
name1 = "barrel of oil equivalent",
name2 = "barrels of oil equivalent",
symbol = "BOE",
utype = "energy",
scale = 6117863200,
default = "GJ",
},
["BTU"] = {
name1 = "British thermal unit",
symbol = "BTU",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
},
["Btu"] = {
name1 = "British thermal unit",
symbol = "Btu",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
},
["BTU-39F"] = {
name1 = "British thermal unit (39°F)",
name2 = "British thermal units (39°F)",
symbol = "BTU<sub>39°F</sub>",
utype = "energy",
scale = 1059.67,
default = "kJ",
link = "British thermal unit",
},
["Btu-39F"] = {
name1 = "British thermal unit (39°F)",
name2 = "British thermal units (39°F)",
symbol = "Btu<sub>39°F</sub>",
utype = "energy",
scale = 1059.67,
default = "kJ",
link = "British thermal unit",
},
["BTU-59F"] = {
name1 = "British thermal unit (59°F)",
name2 = "British thermal units (59°F)",
symbol = "BTU<sub>59°F</sub>",
utype = "energy",
scale = 1054.804,
default = "kJ",
link = "British thermal unit",
},
["Btu-59F"] = {
name1 = "British thermal unit (59°F)",
name2 = "British thermal units (59°F)",
symbol = "Btu<sub>59°F</sub>",
utype = "energy",
scale = 1054.804,
default = "kJ",
link = "British thermal unit",
},
["BTU-60F"] = {
name1 = "British thermal unit (60°F)",
name2 = "British thermal units (60°F)",
symbol = "BTU<sub>60°F</sub>",
utype = "energy",
scale = 1054.68,
default = "kJ",
link = "British thermal unit",
},
["Btu-60F"] = {
name1 = "British thermal unit (60°F)",
name2 = "British thermal units (60°F)",
symbol = "Btu<sub>60°F</sub>",
utype = "energy",
scale = 1054.68,
default = "kJ",
link = "British thermal unit",
},
["BTU-63F"] = {
name1 = "British thermal unit (63°F)",
name2 = "British thermal units (63°F)",
symbol = "BTU<sub>63°F</sub>",
utype = "energy",
scale = 1054.6,
default = "kJ",
link = "British thermal unit",
},
["Btu-63F"] = {
name1 = "British thermal unit (63°F)",
name2 = "British thermal units (63°F)",
symbol = "Btu<sub>63°F</sub>",
utype = "energy",
scale = 1054.6,
default = "kJ",
link = "British thermal unit",
},
["BTU-ISO"] = {
name1 = "British thermal unit (ISO)",
name2 = "British thermal units (ISO)",
symbol = "BTU<sub>ISO</sub>",
utype = "energy",
scale = 1055.056,
default = "kJ",
link = "British thermal unit",
},
["Btu-ISO"] = {
target = "BTU-ISO",
},
["BTU-IT"] = {
name1 = "British thermal unit (IT)",
name2 = "British thermal units (IT)",
symbol = "BTU<sub>IT</sub>",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
link = "British thermal unit",
},
["Btu-IT"] = {
name1 = "British thermal unit (IT)",
name2 = "British thermal units (IT)",
symbol = "Btu<sub>IT</sub>",
utype = "energy",
scale = 1055.05585262,
default = "kJ",
link = "British thermal unit",
},
["BTU-mean"] = {
name1 = "British thermal unit (mean)",
name2 = "British thermal units (mean)",
symbol = "BTU<sub>mean</sub>",
utype = "energy",
scale = 1055.87,
default = "kJ",
link = "British thermal unit",
},
["Btu-mean"] = {
name1 = "British thermal unit (mean)",
name2 = "British thermal units (mean)",
symbol = "Btu<sub>mean</sub>",
utype = "energy",
scale = 1055.87,
default = "kJ",
link = "British thermal unit",
},
["BTU-th"] = {
name1 = "British thermal unit (thermochemical)",
name2 = "British thermal units (thermochemical)",
symbol = "BTU<sub>th</sub>",
utype = "energy",
scale = 1054.35026444,
default = "kJ",
link = "British thermal unit",
},
["Btu-th"] = {
name1 = "British thermal unit (thermochemical)",
name2 = "British thermal units (thermochemical)",
symbol = "Btu<sub>th</sub>",
utype = "energy",
scale = 1054.35026444,
default = "kJ",
link = "British thermal unit",
},
["Cal"] = {
name1 = "calorie",
symbol = "Cal",
utype = "energy",
scale = 4184,
default = "kJ",
},
["cal"] = {
name1 = "calorie",
symbol = "cal",
utype = "energy",
scale = 4.184,
default = "J",
},
["Cal-15"] = {
name1 = "Calorie (15°C)",
name2 = "Calories (15°C)",
symbol = "Cal<sub>15</sub>",
utype = "energy",
scale = 4185.8,
default = "kJ",
link = "Calorie",
},
["cal-15"] = {
name1 = "calorie (15°C)",
name2 = "calories (15°C)",
symbol = "cal<sub>15</sub>",
utype = "energy",
scale = 4.1858,
default = "J",
link = "Calorie",
},
["Cal-IT"] = {
name1 = "Calorie (International Steam Table)",
name2 = "Calories (International Steam Table)",
symbol = "Cal<sub>IT</sub>",
utype = "energy",
scale = 4186.8,
default = "kJ",
link = "Calorie",
},
["cal-IT"] = {
name1 = "calorie (International Steam Table)",
name2 = "calories (International Steam Table)",
symbol = "cal<sub>IT</sub>",
utype = "energy",
scale = 4.1868,
default = "J",
link = "Calorie",
},
["Cal-th"] = {
name1 = "Calorie (thermochemical)",
name2 = "Calories (thermochemical)",
symbol = "Cal<sub>th</sub>",
utype = "energy",
scale = 4184,
default = "kJ",
link = "Calorie",
},
["cal-th"] = {
name1 = "calorie (thermochemical)",
name2 = "calories (thermochemical)",
symbol = "cal<sub>th</sub>",
utype = "energy",
scale = 4.184,
default = "J",
link = "Calorie",
},
["CHU-IT"] = {
name1 = "Celsius heat unit (International Table)",
name2 = "Celsius heat units (International Table)",
symbol = "CHU<sub>IT</sub>",
utype = "energy",
scale = 1899.100534716,
default = "kJ",
link = "Conversion of units#Energy",
},
["cufootnaturalgas"] = {
name1 = "cubic foot of natural gas",
name2 = "cubic foot of natural gas",
symbol = "cuftnaturalgas",
usename = 1,
utype = "energy",
scale = 1055055.85262,
default = "MJ",
link = "Conversion of units#Energy",
},
["cuftnaturalgas"] = {
name1 = "cubic foot of natural gas",
name2 = "cubic feet of natural gas",
symbol = "cuftnaturalgas",
usename = 1,
utype = "energy",
scale = 1055055.85262,
default = "MJ",
link = "Conversion of units#Energy",
},
["Eh"] = {
name1 = "Hartree",
symbol = "''E''<sub>h</sub>",
utype = "energy",
scale = 4.35974417e-18,
default = "eV",
},
["erg"] = {
symbol = "erg",
utype = "energy",
scale = 0.0000001,
default = "μJ",
},
["eV"] = {
name1 = "electronvolt",
symbol = "eV",
utype = "energy",
scale = 1.602176487e-19,
default = "aJ",
},
["feV"] = {
name1 = "femtoelectronvolt",
symbol = "feV",
utype = "energy",
scale = 1.602176487e-34,
default = "yJ",
link = "Electronvolt",
},
["foe"] = {
symbol = "foe",
utype = "energy",
scale = 1e44,
default = "YJ",
link = "Foe (unit)",
},
["ftlb"] = {
name1 = "foot-pound",
symbol = "ft⋅lb",
utype = "energy",
alttype = "torque",
scale = 1.3558179483314004,
default = "J",
link = "Foot-pound (energy)",
},
["ftlb-f"] = {
name1 = "foot-pound force",
name2 = "foot-pounds force",
symbol = "ft⋅lb<sub>f</sub>",
utype = "energy",
alttype = "torque",
scale = 1.3558179483314004,
default = "J",
link = "Foot-pound (energy)",
},
["ftlbf"] = {
name1 = "foot-pound force",
name2 = "foot-pounds force",
symbol = "ft⋅lbf",
utype = "energy",
alttype = "torque",
scale = 1.3558179483314004,
default = "J",
link = "Foot-pound (energy)",
},
["ftpdl"] = {
name1 = "foot-poundal",
symbol = "ft⋅pdl",
utype = "energy",
scale = 0.0421401100938048,
default = "J",
},
["GeV"] = {
name1 = "gigaelectronvolt",
symbol = "GeV",
utype = "energy",
scale = 1.602176487e-10,
default = "nJ",
link = "Electronvolt",
},
["gTNT"] = {
name2 = "grams of TNT",
symbol = "gram of TNT",
usename = 1,
utype = "energy",
scale = 4184,
default = "kJ",
link = "TNT equivalent",
},
["Gtoe"] = {
name1 = "gigatonne of oil equivalent",
name2 = "gigatonnes of oil equivalent",
symbol = "Gtoe",
utype = "energy",
scale = 4.1868e19,
default = "EJ",
link = "Tonne of oil equivalent",
},
["GtonTNT"] = {
name2 = "gigatons of TNT",
symbol = "gigaton of TNT",
usename = 1,
utype = "energy",
scale = 4.184e18,
default = "EJ",
link = "TNT equivalent",
},
["GtTNT"] = {
name2 = "gigatonnes of TNT",
symbol = "gigatonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e18,
default = "EJ",
link = "TNT equivalent",
},
["GW.h"] = {
name1 = "gigawatt-hour",
symbol = "GW⋅h",
utype = "energy",
scale = 3.6e12,
default = "TJ",
link = "Kilowatt-hour",
},
["GWh"] = {
name1 = "gigawatt-hour",
symbol = "GWh",
utype = "energy",
scale = 3.6e12,
default = "TJ",
link = "Kilowatt-hour",
},
["hph"] = {
name1 = "horsepower-hour",
symbol = "hp⋅h",
utype = "energy",
scale = 2684519.537696172792,
default = "kWh",
link = "Horsepower",
},
["inlb"] = {
name1 = "inch-pound",
symbol = "in⋅lb",
utype = "energy",
alttype = "torque",
scale = 0.1129848290276167,
default = "mJ",
link = "Foot-pound (energy)",
},
["inlb-f"] = {
name1 = "inch-pound force",
name2 = "inch-pounds force",
symbol = "in⋅lb<sub>f</sub>",
utype = "energy",
alttype = "torque",
scale = 0.1129848290276167,
default = "mJ",
link = "Foot-pound (energy)",
},
["inlbf"] = {
name1 = "inch-pound force",
name2 = "inch-pounds force",
symbol = "in⋅lbf",
utype = "energy",
alttype = "torque",
scale = 0.1129848290276167,
default = "mJ",
link = "Foot-pound (energy)",
},
["inoz-f"] = {
name1 = "inch-ounce force",
name2 = "inch-ounces force",
symbol = "in⋅oz<sub>f</sub>",
utype = "energy",
alttype = "torque",
scale = 0.00706155181422604375,
default = "mJ",
link = "Foot-pound (energy)",
},
["inozf"] = {
name1 = "inch-ounce force",
name2 = "inch-ounces force",
symbol = "in⋅ozf",
utype = "energy",
alttype = "torque",
scale = 0.00706155181422604375,
default = "mJ",
link = "Foot-pound (energy)",
},
["J"] = {
_name1 = "joule",
_symbol = "J",
utype = "energy",
scale = 1,
prefixes = 1,
default = "cal",
link = "Joule",
},
["kBOE"] = {
name1 = "kilo barrel of oil equivalent",
name2 = "kilo barrels of oil equivalent",
symbol = "kBOE",
utype = "energy",
scale = 6.1178632e12,
default = "TJ",
link = "Barrel of oil equivalent",
},
["kcal"] = {
name1 = "kilocalorie",
symbol = "kcal",
utype = "energy",
scale = 4184,
default = "kJ",
link = "Calorie",
},
["kcal-15"] = {
name1 = "kilocalorie (15°C)",
name2 = "kilocalories (15°C)",
symbol = "kcal<sub>15</sub>",
utype = "energy",
scale = 4185.8,
default = "kJ",
link = "Calorie",
},
["kcal-IT"] = {
name1 = "kilocalorie (International Steam Table)",
name2 = "kilocalories (International Steam Table)",
symbol = "kcal<sub>IT</sub>",
utype = "energy",
scale = 4186.8,
default = "kJ",
link = "Calorie",
},
["kcal-th"] = {
name1 = "kilocalorie (thermochemical)",
name2 = "kilocalories (thermochemical)",
symbol = "kcal<sub>th</sub>",
utype = "energy",
scale = 4184,
default = "kJ",
link = "Calorie",
},
["kerg"] = {
name1 = "kiloerg",
symbol = "kerg",
utype = "energy",
scale = 0.0001,
default = "mJ",
link = "Erg",
},
["keV"] = {
name1 = "kiloelectronvolt",
symbol = "keV",
utype = "energy",
scale = 1.602176487e-16,
default = "fJ",
link = "Electronvolt",
},
["kgTNT"] = {
name2 = "kilograms of TNT",
symbol = "kilogram of TNT",
usename = 1,
utype = "energy",
scale = 4184000,
default = "MJ",
link = "TNT equivalent",
},
["kt(TNT)"] = {
name1 = "kilotonne",
name1_us = "kiloton",
symbol = "kt",
utype = "energy",
scale = 4.184e12,
default = "TJ",
link = "TNT equivalent",
},
["ktoe"] = {
name1 = "kilotonne of oil equivalent",
name2 = "kilotonnes of oil equivalent",
symbol = "ktoe",
utype = "energy",
scale = 4.1868e13,
default = "TJ",
link = "Tonne of oil equivalent",
},
["ktonTNT"] = {
name1 = "kiloton of TNT",
name2 = "kilotons of TNT",
symbol = "kt",
utype = "energy",
scale = 4.184e12,
default = "TJ",
link = "TNT equivalent",
},
["ktTNT"] = {
name2 = "kilotonnes of TNT",
symbol = "kilotonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e12,
default = "TJ",
link = "TNT equivalent",
},
["kW.h"] = {
name1 = "kilowatt-hour",
symbol = "kW⋅h",
utype = "energy",
scale = 3600000,
default = "MJ",
},
["kWh"] = {
name1 = "kilowatt-hour",
symbol = "kWh",
utype = "energy",
scale = 3600000,
default = "MJ",
},
["Mcal"] = {
name1 = "megacalorie",
symbol = "Mcal",
utype = "energy",
scale = 4184000,
default = "MJ",
link = "Calorie",
},
["mcal"] = {
name1 = "millicalorie",
symbol = "mcal",
utype = "energy",
scale = 0.004184,
default = "mJ",
link = "Calorie",
},
["Mcal-15"] = {
name1 = "megacalorie (15°C)",
name2 = "megacalories (15°C)",
symbol = "Mcal<sub>15</sub>",
utype = "energy",
scale = 4185800,
default = "MJ",
link = "Calorie",
},
["mcal-15"] = {
name1 = "millicalorie (15°C)",
name2 = "millicalories (15°C)",
symbol = "mcal<sub>15</sub>",
utype = "energy",
scale = 0.0041858,
default = "mJ",
link = "Calorie",
},
["Mcal-IT"] = {
name1 = "megacalorie (International Steam Table)",
name2 = "megacalories (International Steam Table)",
symbol = "Mcal<sub>IT</sub>",
utype = "energy",
scale = 4186800,
default = "MJ",
link = "Calorie",
},
["mcal-IT"] = {
name1 = "millicalorie (International Steam Table)",
name2 = "millicalories (International Steam Table)",
symbol = "mcal<sub>IT</sub>",
utype = "energy",
scale = 0.0041868,
default = "mJ",
link = "Calorie",
},
["Mcal-th"] = {
name1 = "megacalorie (thermochemical)",
name2 = "megacalories (thermochemical)",
symbol = "Mcal<sub>th</sub>",
utype = "energy",
scale = 4184000,
default = "MJ",
link = "Calorie",
},
["mcal-th"] = {
name1 = "millicalorie (thermochemical)",
name2 = "millicalories (thermochemical)",
symbol = "mcal<sub>th</sub>",
utype = "energy",
scale = 0.004184,
default = "mJ",
link = "Calorie",
},
["Merg"] = {
name1 = "megaerg",
symbol = "Merg",
utype = "energy",
scale = 0.1,
default = "J",
link = "Erg",
},
["merg"] = {
name1 = "millierg",
symbol = "merg",
utype = "energy",
scale = 0.0000000001,
default = "μJ",
link = "Erg",
},
["MeV"] = {
name1 = "megaelectronvolt",
symbol = "MeV",
utype = "energy",
scale = 1.602176487e-13,
default = "pJ",
link = "Electronvolt",
},
["meV"] = {
name1 = "millielectronvolt",
symbol = "meV",
utype = "energy",
scale = 1.602176487e-22,
default = "zJ",
link = "Electronvolt",
},
["MMBtu"] = {
name1 = "million British thermal units",
name2 = "million British thermal units",
symbol = "MMBtu",
utype = "energy",
scale = 1055055852.62,
default = "GJ",
link = "British thermal unit",
},
["Mt(TNT)"] = {
name1 = "megatonne",
name1_us = "megaton",
symbol = "Mt",
utype = "energy",
scale = 4.184e15,
default = "PJ",
link = "TNT equivalent",
},
["Mtoe"] = {
name1 = "megatonne of oil equivalent",
name2 = "megatonnes of oil equivalent",
symbol = "Mtoe",
utype = "energy",
scale = 4.1868e16,
default = "PJ",
link = "Tonne of oil equivalent",
},
["MtonTNT"] = {
name1 = "megaton of TNT",
name2 = "megatons of TNT",
symbol = "Mt",
utype = "energy",
scale = 4.184e15,
default = "PJ",
link = "TNT equivalent",
},
["mtonTNT"] = {
name2 = "millitons of TNT",
symbol = "milliton of TNT",
usename = 1,
utype = "energy",
scale = 4184000,
default = "MJ",
link = "TNT equivalent",
},
["MtTNT"] = {
name2 = "megatonnes of TNT",
symbol = "megatonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e15,
default = "PJ",
link = "TNT equivalent",
},
["mtTNT"] = {
name2 = "millitonnes of TNT",
symbol = "millitonne of TNT",
usename = 1,
utype = "energy",
scale = 4184000,
default = "MJ",
link = "TNT equivalent",
},
["MW.h"] = {
name1 = "megawatt-hour",
symbol = "MW⋅h",
utype = "energy",
scale = 3600000000,
default = "GJ",
link = "Kilowatt-hour",
},
["mW.h"] = {
name1 = "milliwatt-hour",
symbol = "mW⋅h",
utype = "energy",
scale = 3.6,
default = "J",
link = "Kilowatt-hour",
},
["MWh"] = {
name1 = "megawatt-hour",
symbol = "MWh",
utype = "energy",
scale = 3600000000,
default = "GJ",
link = "Kilowatt-hour",
},
["mWh"] = {
name1 = "milliwatt-hour",
symbol = "mWh",
utype = "energy",
scale = 3.6,
default = "J",
link = "Kilowatt-hour",
},
["neV"] = {
name1 = "nanoelectronvolt",
symbol = "neV",
utype = "energy",
scale = 1.602176487e-28,
default = "yJ",
link = "Electronvolt",
},
["PeV"] = {
name1 = "petaelectronvolt",
symbol = "PeV",
utype = "energy",
scale = 0.0001602176487,
default = "mJ",
link = "Electronvolt",
},
["peV"] = {
name1 = "picoelectronvolt",
symbol = "peV",
utype = "energy",
scale = 1.602176487e-31,
default = "yJ",
link = "Electronvolt",
},
["PSh"] = {
name1 = "Pferdestärkenstunde",
symbol = "PSh",
utype = "energy",
scale = 2647795.5,
default = "kWh",
},
["quad"] = {
name1 = "quadrillion British thermal units",
name2 = "quadrillion British thermal units",
symbol = "quad",
utype = "energy",
scale = 1.054804e18,
default = "EJ",
link = "Quad (unit)",
},
["Ry"] = {
name1 = "rydberg",
symbol = "Ry",
utype = "energy",
scale = 2.1798741e-18,
default = "eV",
link = "Rydberg constant",
},
["scf"] = {
name1 = "standard cubic foot",
name2 = "standard cubic feet",
symbol = "scf",
utype = "energy",
scale = 2869.2044809344,
default = "kJ",
},
["scfoot"] = {
name1 = "standard cubic foot",
name2 = "standard cubic foot",
symbol = "scf",
utype = "energy",
scale = 2869.2044809344,
default = "kJ",
},
["t(TNT)"] = {
name1 = "tonne",
name1_us = "ton",
symbol = "t",
utype = "energy",
scale = 4184000000,
default = "GJ",
link = "TNT equivalent",
},
["TeV"] = {
name1 = "teraelectronvolt",
symbol = "TeV",
utype = "energy",
scale = 1.602176487e-7,
default = "μJ",
link = "Electronvolt",
},
["th"] = {
name1 = "thermie",
symbol = "th",
utype = "energy",
scale = 4186800,
default = "MJ",
link = "Conversion of units#Energy",
},
["thm-EC"] = {
name1 = "therm (EC)",
name2 = "therms (EC)",
symbol = "thm (EC)",
utype = "energy",
scale = 105506000,
default = "MJ",
link = "Therm",
},
["thm-UK"] = {
name1 = "therm (UK)",
name2 = "therms (UK)",
symbol = "thm (UK)",
utype = "energy",
scale = 105505585.257348,
default = "MJ",
link = "Therm",
},
["thm-US"] = {
name1 = "therm (US)",
name1_us = "therm (U.S.)",
name2 = "therms (US)",
name2_us = "therms (U.S.)",
symbol = "thm (US)",
sym_us = "thm (U.S.)",
utype = "energy",
scale = 105480400,
default = "MJ",
link = "Therm",
},
["toe"] = {
name1 = "tonne of oil equivalent",
name2 = "tonnes of oil equivalent",
symbol = "toe",
utype = "energy",
scale = 41868000000,
default = "GJ",
},
["tonTNT"] = {
name2 = "tons of TNT",
symbol = "ton of TNT",
usename = 1,
utype = "energy",
scale = 4184000000,
default = "GJ",
link = "TNT equivalent",
},
["tTNT"] = {
name2 = "tonnes of TNT",
symbol = "tonne of TNT",
usename = 1,
utype = "energy",
scale = 4184000000,
default = "GJ",
link = "TNT equivalent",
},
["TtonTNT"] = {
name2 = "teratons of TNT",
symbol = "teraton of TNT",
usename = 1,
utype = "energy",
scale = 4.184e21,
default = "ZJ",
link = "TNT equivalent",
},
["TtTNT"] = {
name2 = "teratonnes of TNT",
symbol = "teratonne of TNT",
usename = 1,
utype = "energy",
scale = 4.184e21,
default = "ZJ",
link = "TNT equivalent",
},
["TW.h"] = {
name1 = "terawatt-hour",
symbol = "TW⋅h",
utype = "energy",
scale = 3.6e15,
default = "PJ",
link = "Kilowatt-hour",
},
["TWh"] = {
name1 = "terawatt-hour",
symbol = "TWh",
utype = "energy",
scale = 3.6e15,
default = "PJ",
link = "Kilowatt-hour",
},
["W.h"] = {
name1 = "watt-hour",
symbol = "W⋅h",
utype = "energy",
scale = 3600,
default = "kJ",
link = "Kilowatt-hour",
},
["Wh"] = {
name1 = "watt-hour",
symbol = "Wh",
utype = "energy",
scale = 3600,
default = "kJ",
link = "Kilowatt-hour",
},
["μerg"] = {
name1 = "microerg",
symbol = "μerg",
utype = "energy",
scale = 1e-13,
default = "nJ",
link = "Erg",
},
["μeV"] = {
name1 = "microelectronvolt",
symbol = "μeV",
utype = "energy",
scale = 1.602176487e-25,
default = "yJ",
link = "Electronvolt",
},
["μW.h"] = {
name1 = "microwatt-hour",
symbol = "μW⋅h",
utype = "energy",
scale = 0.0036,
default = "mJ",
link = "Kilowatt-hour",
},
["μWh"] = {
name1 = "microwatt-hour",
symbol = "μWh",
utype = "energy",
scale = 0.0036,
default = "mJ",
link = "Kilowatt-hour",
},
["-kW.h"] = {
target = "kW.h",
link = "Kilowatt hour",
},
["btu"] = {
target = "BTU",
},
["Calorie"] = {
target = "Cal",
},
["ft.lbf"] = {
target = "ftlbf",
},
["ft·lbf"] = {
target = "ftlbf",
},
["g-cal-15"] = {
target = "cal-15",
},
["g-cal-IT"] = {
target = "cal-IT",
},
["g-cal-th"] = {
target = "cal-th",
},
["g-kcal-15"] = {
target = "kcal-15",
},
["g-kcal-IT"] = {
target = "kcal-IT",
},
["g-kcal-th"] = {
target = "kcal-th",
},
["g-Mcal-15"] = {
target = "Mcal-15",
},
["g-mcal-15"] = {
target = "mcal-15",
},
["g-Mcal-IT"] = {
target = "Mcal-IT",
},
["g-mcal-IT"] = {
target = "mcal-IT",
},
["g-Mcal-th"] = {
target = "Mcal-th",
},
["g-mcal-th"] = {
target = "mcal-th",
},
["GW-h"] = {
target = "GW.h",
},
["GW·h"] = {
target = "GW.h",
},
["Hartree"] = {
target = "Eh",
},
["hp.h"] = {
target = "hph",
},
["in.lb-f"] = {
target = "inlb-f",
},
["in.lbf"] = {
target = "inlbf",
},
["in.oz-f"] = {
target = "inoz-f",
},
["in.ozf"] = {
target = "inozf",
},
["kbboe"] = {
target = "kBOE",
symbol = "kbboe",
},
["kg-cal-15"] = {
target = "Cal-15",
},
["kg-cal-IT"] = {
target = "Cal-IT",
},
["kg-cal-th"] = {
target = "Cal-th",
},
["kW-h"] = {
target = "kW.h",
},
["kW·h"] = {
target = "kW.h",
},
["MW-h"] = {
target = "MW.h",
},
["mW-h"] = {
target = "mW.h",
},
["MW·h"] = {
target = "MW.h",
},
["TW-h"] = {
target = "TW.h",
},
["uerg"] = {
target = "μerg",
},
["ueV"] = {
target = "μeV",
},
["uW-h"] = {
target = "μW.h",
},
["uW.h"] = {
target = "μW.h",
},
["uWh"] = {
target = "μWh",
},
["W-h"] = {
target = "W.h",
},
["eVpar"] = {
_name1 = "electronvolt",
_symbol = "eV",
utype = "energy per chemical amount",
scale = 96485.329522144166,
prefixes = 1,
default = "kcal/mol",
link = "Electronvolt",
},
["kcal/mol"] = {
per = { "kcal", "mol" },
utype = "energy per chemical amount",
default = "kJ/mol",
link = "Kilocalorie per mole",
},
["kJ/mol"] = {
per = { "kJ", "mol" },
utype = "energy per chemical amount",
default = "kcal/mol",
link = "Joule per mole",
},
["kWh/100 km"] = {
name1 = "kilowatt-hour per 100 kilometres",
name1_us = "kilowatt-hour per 100 kilometers",
name2 = "kilowatt-hours per 100 kilometres",
name2_us = "kilowatt-hours per 100 kilometers",
symbol = "kW⋅h/100 km",
utype = "energy per unit length",
scale = 36,
default = "MJ/km kWh/mi",
link = "Kilowatt-hour",
},
["kWh/100 mi"] = {
name1 = "kilowatt-hour per 100 miles",
name2 = "kilowatt-hours per 100 miles",
symbol = "kW⋅h/100 mi",
utype = "energy per unit length",
scale = 22.3694,
default = "mpge",
link = "Miles per gallon gasoline equivalent",
},
["MJ/100 km"] = {
name1 = "megajoule per 100 kilometres",
name1_us = "megajoule per 100 kilometers",
name2 = "megajoules per 100 kilometres",
name2_us = "megajoules per 100 kilometers",
symbol = "MJ/100 km",
utype = "energy per unit length",
scale = 10,
default = "BTU/mi",
link = "British thermal unit",
},
["mpge"] = {
name1 = "mile per gallon gasoline equivalent",
name2 = "miles per gallon gasoline equivalent",
symbol = "mpg‑e",
utype = "energy per unit length",
scale = 1.3263314048360777e-5,
invert = -1,
iscomplex= true,
default = "kWh/100 mi",
link = "Miles per gallon gasoline equivalent",
},
["BTU/mi"] = {
per = { "BTU", "mi" },
utype = "energy per unit length",
default = "v > 1525 ! M ! k ! J/km",
},
["kJ/km"] = {
per = { "kJ", "km" },
utype = "energy per unit length",
default = "BTU/mi",
},
["kWh/km"] = {
per = { "-kW.h", "km" },
utype = "energy per unit length",
default = "MJ/km kWh/mi",
},
["kWh/mi"] = {
per = { "-kW.h", "mi" },
utype = "energy per unit length",
default = "kWh/km MJ/km",
},
["MJ/km"] = {
per = { "MJ", "km" },
utype = "energy per unit length",
default = "BTU/mi",
},
["mpg-e"] = {
target = "mpge",
},
["BTU/lb"] = {
name1 = "British thermal unit per pound",
name2 = "British thermal units per pound",
symbol = "BTU/lb",
utype = "energy per unit mass",
scale = 2326,
default = "kJ/kg",
link = "British thermal unit",
},
["cal/g"] = {
name1 = "calorie per gram",
name2 = "calories per gram",
symbol = "cal/g",
utype = "energy per unit mass",
scale = 4184,
default = "J/g",
},
["GJ/kg"] = {
name1 = "gigajoule per kilogram",
name2 = "gigajoules per kilogram",
symbol = "GJ/kg",
utype = "energy per unit mass",
scale = 1e9,
default = "ktTNT/t",
link = "Specific energy",
},
["J/g"] = {
name1 = "joule per gram",
name2 = "joules per gram",
symbol = "J/g",
utype = "energy per unit mass",
scale = 1000,
default = "kcal/g",
link = "Specific energy",
},
["kcal/g"] = {
name1 = "kilocalorie per gram",
name2 = "kilocalories per gram",
symbol = "kcal/g",
utype = "energy per unit mass",
scale = 4184000,
default = "kJ/g",
},
["kJ/g"] = {
name1 = "kilojoule per gram",
name2 = "kilojoules per gram",
symbol = "kJ/g",
utype = "energy per unit mass",
scale = 1000000,
default = "kcal/g",
link = "Specific energy",
},
["kJ/kg"] = {
name1 = "kilojoule per kilogram",
name2 = "kilojoules per kilogram",
symbol = "kJ/kg",
utype = "energy per unit mass",
scale = 1000,
default = "BTU/lb",
link = "Specific energy",
},
["ktonTNT/MT"] = {
name2 = "kilotons of TNT per metric ton",
symbol = "kiloton of TNT per metric ton",
usename = 1,
utype = "energy per unit mass",
scale = 4184000000,
default = "GJ/kg",
link = "TNT equivalent",
},
["ktTNT/t"] = {
name2 = "kilotonnes of TNT per tonne",
symbol = "kilotonne of TNT per tonne",
usename = 1,
utype = "energy per unit mass",
scale = 4184000000,
default = "GJ/kg",
link = "TNT equivalent",
},
["MtonTNT/MT"] = {
name2 = "megatons of TNT per metric ton",
symbol = "megaton of TNT per metric ton",
usename = 1,
utype = "energy per unit mass",
scale = 4.184e12,
default = "TJ/kg",
link = "TNT equivalent",
},
["MtTNT/MT"] = {
name2 = "megatonnes of TNT per tonne",
symbol = "megatonne of TNT per tonne",
usename = 1,
utype = "energy per unit mass",
scale = 4.184e12,
default = "TJ/kg",
link = "TNT equivalent",
},
["TJ/kg"] = {
name1 = "terajoule per kilogram",
name2 = "terajoules per kilogram",
symbol = "TJ/kg",
utype = "energy per unit mass",
scale = 1e12,
default = "MtTNT/MT",
link = "Specific energy",
},
["Cal/g"] = {
per = { "Cal", "g" },
utype = "energy per unit mass",
default = "kJ/g",
},
["BTU/cuft"] = {
per = { "BTU", "cuft" },
utype = "energy per unit volume",
default = "kJ/L",
},
["Cal/12USoz(mL)serve"] = {
per = { "Cal", "-12USoz(mL)serve" },
utype = "energy per unit volume",
default = "kJ/L",
},
["Cal/12USoz(ml)serve"] = {
per = { "Cal", "-12USoz(ml)serve" },
utype = "energy per unit volume",
default = "kJ/l",
},
["Cal/12USozserve"] = {
per = { "Cal", "-12USozserve" },
utype = "energy per unit volume",
default = "kJ/L",
},
["Cal/USoz"] = {
per = { "Cal", "USoz" },
utype = "energy per unit volume",
default = "kJ/ml",
},
["kJ/L"] = {
per = { "kJ", "L" },
utype = "energy per unit volume",
default = "BTU/cuft",
},
["kJ/l"] = {
per = { "kJ", "ll" },
utype = "energy per unit volume",
default = "BTU/cuft",
},
["kJ/ml"] = {
per = { "kJ", "ml" },
utype = "energy per unit volume",
default = "Cal/USoz",
},
["MJ/m3"] = {
per = { "MJ", "m3" },
utype = "energy per unit volume",
default = "BTU/cuft",
},
["Sv"] = {
_name1 = "sievert",
_symbol = "Sv",
utype = "equivalent radiation dose",
scale = 1,
prefixes = 1,
default = "rem",
link = "Sievert",
},
["rem"] = {
_name1 = "rem",
_symbol = "rem",
utype = "equivalent radiation dose",
scale = 0.01,
prefixes = 1,
default = "Sv",
link = "Roentgen equivalent man",
},
["g/km"] = {
name1 = "gram per kilometre",
name1_us = "gram per kilometer",
name2 = "grams per kilometre",
name2_us = "grams per kilometer",
symbol = "g/km",
utype = "exhaust emission",
scale = 1e-6,
default = "oz/mi",
link = "Exhaust gas",
},
["g/mi"] = {
name1 = "gram per mile",
name2 = "grams per mile",
symbol = "g/mi",
utype = "exhaust emission",
scale = 6.2137119223733397e-7,
default = "g/km",
link = "Exhaust gas",
},
["gCO2/km"] = {
name1 = "gram of CO<sub>2</sub> per kilometre",
name1_us = "gram of CO<sub>2</sub> per kilometer",
name2 = "grams of CO<sub>2</sub> per kilometre",
name2_us = "grams of CO<sub>2</sub> per kilometer",
symbol = "g(CO<sub>2</sub>)/km",
utype = "exhaust emission",
scale = 1e-6,
default = "ozCO2/mi",
link = "Exhaust gas",
},
["gCO2/mi"] = {
name1 = "gram of CO<sub>2</sub> per mile",
name2 = "grams of CO<sub>2</sub> per mile",
symbol = "g(CO<sub>2</sub>)/mi",
utype = "exhaust emission",
scale = 6.2137119223733397e-7,
default = "gCO2/km",
link = "Exhaust gas",
},
["kg/km"] = {
name1 = "kilogram per kilometre",
name1_us = "kilogram per kilometer",
name2 = "kilograms per kilometre",
name2_us = "kilograms per kilometer",
symbol = "kg/km",
utype = "exhaust emission",
scale = 0.001,
default = "lb/mi",
link = "Exhaust gas",
},
["kgCO2/km"] = {
name1 = "kilogram of CO<sub>2</sub> per kilometre",
name1_us = "kilogram of CO<sub>2</sub> per kilometer",
name2 = "kilograms of CO<sub>2</sub> per kilometre",
name2_us = "kilograms of CO<sub>2</sub> per kilometer",
symbol = "kg(CO<sub>2</sub>)/km",
utype = "exhaust emission",
scale = 0.001,
default = "lbCO2/mi",
link = "Exhaust gas",
},
["lb/mi"] = {
name1 = "pound per mile",
name2 = "pounds per mile",
symbol = "lb/mi",
utype = "exhaust emission",
scale = 0.00028184923173665794,
default = "kg/km",
link = "Exhaust gas",
},
["lbCO2/mi"] = {
name1 = "pound of CO<sub>2</sub> per mile",
name2 = "pounds of CO<sub>2</sub> per mile",
symbol = "lb(CO<sub>2</sub>)/mi",
utype = "exhaust emission",
scale = 0.00028184923173665794,
default = "kgCO2/km",
link = "Exhaust gas",
},
["oz/mi"] = {
name1 = "ounce per mile",
name2 = "ounces per mile",
symbol = "oz/mi",
utype = "exhaust emission",
scale = 1.7615576983541121e-5,
default = "g/km",
link = "Exhaust gas",
},
["ozCO2/mi"] = {
name1 = "ounce of CO<sub>2</sub> per mile",
name2 = "ounces of CO<sub>2</sub> per mile",
symbol = "oz(CO<sub>2</sub>)/mi",
utype = "exhaust emission",
scale = 1.7615576983541121e-5,
default = "gCO2/km",
link = "Exhaust gas",
},
["cuft/a"] = {
name1 = "cubic foot per annum",
name2 = "cubic feet per annum",
symbol = "cu ft/a",
utype = "flow",
scale = 8.9730672142368242e-10,
default = "m3/a",
link = "Cubic foot per second",
},
["cuft/d"] = {
name1 = "cubic foot per day",
name2 = "cubic feet per day",
symbol = "cu ft/d",
utype = "flow",
scale = 3.2774128000000003e-7,
default = "m3/d",
link = "Cubic foot per second",
},
["cuft/h"] = {
name1 = "cubic foot per hour",
name2 = "cubic feet per hour",
symbol = "cu ft/h",
utype = "flow",
scale = 7.8657907200000004e-6,
default = "m3/h",
link = "Cubic foot per second",
},
["cuft/min"] = {
name1 = "cubic foot per minute",
name2 = "cubic feet per minute",
symbol = "cu ft/min",
utype = "flow",
scale = 0.00047194744319999999,
default = "m3/min",
},
["cuft/s"] = {
name1 = "cubic foot per second",
name2 = "cubic feet per second",
symbol = "cu ft/s",
utype = "flow",
scale = 28316846592e-12,
default = "m3/s",
},
["cumi/a"] = {
name1 = "cubic mile per annum",
name2 = "cubic miles per annum",
symbol = "cu mi/a",
utype = "flow",
scale = 132.08171170940057,
default = "km3/a",
link = "Cubic foot per second",
},
["cuyd/h"] = {
name1 = "cubic yard per hour",
name2 = "cubic yards per hour",
symbol = "cuyd/h",
utype = "flow",
scale = 0.00021237634944000001,
default = "m3/h",
link = "Cubic foot per second",
},
["cuyd/s"] = {
name1 = "cubic yard per second",
name2 = "cubic yards per second",
symbol = "cu yd/s",
utype = "flow",
scale = 0.76455485798400002,
default = "m3/s",
},
["Goilbbl/a"] = {
name1 = "billion barrels per year",
name2 = "billion barrels per year",
symbol = "Gbbl/a",
utype = "flow",
scale = 5.0380033629933836,
default = "v * 1.58987294928 < 10 ! e6 ! e9 ! m3/a",
link = "Barrel per day",
},
["impgal/h"] = {
name1 = "imperial gallon per hour",
name2 = "imperial gallons per hour",
symbol = "imp gal/h",
utype = "flow",
scale = 1.2628027777777779e-6,
default = "m3/h",
link = "Gallon",
},
["impgal/min"] = {
name1 = "imperial gallon per minute",
name2 = "imperial gallons per minute",
symbol = "imp gal/min",
utype = "flow",
scale = 7.5768166666666671e-5,
default = "m3/s",
link = "Gallon",
},
["impgal/s"] = {
name1 = "imperial gallon per second",
name2 = "imperial gallons per second",
symbol = "impgal/s",
utype = "flow",
scale = 0.00454609,
default = "m3/s",
link = "Imperial gallons per second",
},
["km3/a"] = {
name1 = "cubic kilometre per annum",
name1_us = "cubic kilometer per annum",
name2 = "cubic kilometres per annum",
name2_us = "cubic kilometers per annum",
symbol = "km<sup>3</sup>/a",
utype = "flow",
scale = 31.68808781402895,
default = "cumi/a",
link = "Cubic metre per second",
},
["km3/d"] = {
name1 = "cubic kilometre per day",
name1_us = "cubic kilometer per day",
name2 = "cubic kilometres per day",
name2_us = "cubic kilometers per day",
symbol = "km<sup>3</sup>/d",
utype = "flow",
scale = 11574.074074074075,
default = "cuft/d",
link = "Cubic metre per second",
},
["koilbbl/a"] = {
name1 = "thousand barrels per year",
name2 = "thousand barrels per year",
symbol = "kbbl/a",
utype = "flow",
scale = 5.0380033629933841e-6,
default = "v * 1.58987294928 < 10 ! ! e3 ! m3/a",
link = "Barrel per day",
},
["koilbbl/d"] = {
name1 = "thousand barrels per day",
name2 = "thousand barrels per day",
symbol = "kbbl/d",
utype = "flow",
scale = 0.0018401307283333335,
default = "v * 1.58987294928 < 10 ! ! e3 ! m3/d",
link = "Barrel per day",
},
["L/h"] = {
name1 = "litre per hour",
name1_us = "liter per hour",
name2 = "litres per hour",
name2_us = "liters per hour",
symbol = "L/h",
utype = "flow",
scale = 2.7777777777777776e-7,
default = "impgal/h USgal/h",
link = "Cubic metre per second",
},
["L/min"] = {
name1 = "litre per minute",
name1_us = "liter per minute",
name2 = "litres per minute",
name2_us = "liters per minute",
symbol = "L/min",
utype = "flow",
scale = 1.6666666666666667e-5,
default = "impgal/min USgal/min",
link = "Cubic metre per second",
},
["L/s"] = {
name1 = "litre per second",
name1_us = "liter per second",
name2 = "litres per second",
name2_us = "liters per second",
symbol = "L/s",
utype = "flow",
scale = 0.001,
default = "cuft/s",
link = "Cubic metre per second",
},
["m3/a"] = {
name1 = "cubic metre per annum",
name1_us = "cubic meter per annum",
name2 = "cubic metres per annum",
name2_us = "cubic meters per annum",
symbol = "m<sup>3</sup>/a",
utype = "flow",
scale = 3.1688087814028947e-8,
default = "cuft/a",
link = "Cubic metre per second",
},
["m3/d"] = {
name1 = "cubic metre per day",
name1_us = "cubic meter per day",
name2 = "cubic metres per day",
name2_us = "cubic meters per day",
symbol = "m<sup>3</sup>/d",
utype = "flow",
scale = 1.1574074074074073e-5,
default = "cuft/d",
link = "Cubic metre per second",
},
["m3/h"] = {
name1 = "cubic metre per hour",
name1_us = "cubic meter per hour",
name2 = "cubic metres per hour",
name2_us = "cubic meters per hour",
symbol = "m<sup>3</sup>/h",
utype = "flow",
scale = 0.00027777777777777778,
default = "cuft/h",
link = "Cubic metre per second",
},
["m3/min"] = {
name1 = "cubic metre per minute",
name1_us = "cubic meter per minute",
name2 = "cubic metres per minute",
name2_us = "cubic meters per minute",
symbol = "m<sup>3</sup>/min",
utype = "flow",
scale = 0.016666666666666666,
default = "cuft/min",
link = "Cubic metre per second",
},
["m3/s"] = {
name1 = "cubic metre per second",
name1_us = "cubic meter per second",
name2 = "cubic metres per second",
name2_us = "cubic meters per second",
symbol = "m<sup>3</sup>/s",
utype = "flow",
scale = 1,
default = "cuft/s",
},
["Moilbbl/a"] = {
name1 = "million barrels per year",
name2 = "million barrels per year",
symbol = "Mbbl/a",
utype = "flow",
scale = 0.0050380033629933837,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3/a",
link = "Barrel per day",
},
["Moilbbl/d"] = {
name1 = "million barrels per day",
name2 = "million barrels per day",
symbol = "Mbbl/d",
utype = "flow",
scale = 1.8401307283333335,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3/d",
link = "Barrel per day",
},
["oilbbl/a"] = {
name1 = "barrel per year",
name2 = "barrels per year",
symbol = "bbl/a",
utype = "flow",
scale = 5.0380033629933841e-9,
default = "m3/a",
link = "Barrel per day",
},
["oilbbl/d"] = {
name1 = "barrel per day",
name2 = "barrels per day",
symbol = "bbl/d",
utype = "flow",
scale = 1.8401307283333336e-6,
default = "m3/d",
},
["Toilbbl/a"] = {
name1 = "trillion barrels per year",
name2 = "trillion barrels per year",
symbol = "Tbbl/a",
utype = "flow",
scale = 5038.0033629933832,
default = "v * 1.58987294928 < 10 ! e9 ! e12 ! m3/a",
link = "Barrel per day",
},
["U.S.gal/d"] = {
name1 = "U.S. gallon per day",
name2 = "U.S. gallons per day",
symbol = "U.S. gal/d",
utype = "flow",
scale = 4.3812636388888893e-8,
default = "m3/s",
customary= 1,
},
["U.S.gal/h"] = {
name1 = "gallon per hour",
name2 = "gallons per hour",
symbol = "gal/h",
utype = "flow",
scale = 1.0515032733333334e-6,
default = "m3/h",
link = "Gallon",
customary= 2,
},
["U.S.gal/min"] = {
name1 = "U.S. gallon per minute",
name2 = "U.S. gallons per minute",
symbol = "U.S. gal/min",
utype = "flow",
scale = 6.3090196400000003e-5,
default = "m3/s",
link = "Gallon",
},
["USgal/a"] = {
name1 = "US gallon per year",
name2 = "US gallons per year",
symbol = "US gal/a",
utype = "flow",
scale = 1.1995246102365199e-10,
default = "m3/s",
},
["USgal/d"] = {
name1 = "US gallon per day",
name2 = "US gallons per day",
symbol = "US gal/d",
utype = "flow",
scale = 4.3812636388888893e-8,
default = "m3/s",
},
["USgal/h"] = {
name1 = "gallon per hour",
name2 = "gallons per hour",
symbol = "gal/h",
utype = "flow",
scale = 1.0515032733333334e-6,
default = "m3/h",
link = "Gallon",
customary= 1,
},
["USgal/min"] = {
name1 = "US gallon per minute",
name2 = "US gallons per minute",
symbol = "US gal/min",
utype = "flow",
scale = 6.3090196400000003e-5,
default = "m3/s",
link = "Gallon",
},
["USgal/s"] = {
name1 = "US gallon per second",
name1_us = "U.S. gallon per second",
name2 = "US gallons per second",
name2_us = "U.S. gallons per second",
symbol = "USgal/s",
utype = "flow",
scale = 0.003785411784,
default = "m3/s",
link = "US gallons per second",
},
["ft3/a"] = {
target = "cuft/a",
},
["ft3/d"] = {
target = "cuft/d",
},
["ft3/h"] = {
target = "cuft/h",
},
["ft3/s"] = {
target = "cuft/s",
},
["Gcuft/a"] = {
target = "e9cuft/a",
},
["Gcuft/d"] = {
target = "e9cuft/d",
},
["kcuft/a"] = {
target = "e3cuft/a",
},
["kcuft/d"] = {
target = "e3cuft/d",
},
["kcuft/s"] = {
target = "e3cuft/s",
},
["Mcuft/a"] = {
target = "e6cuft/a",
},
["Mcuft/d"] = {
target = "e6cuft/d",
},
["Mcuft/s"] = {
target = "e6cuft/s",
},
["m³/s"] = {
target = "m3/s",
},
["Tcuft/a"] = {
target = "e12cuft/a",
},
["Tcuft/d"] = {
target = "e12cuft/d",
},
["u.s.gal/min"] = {
target = "U.S.gal/min",
},
["usgal/min"] = {
target = "USgal/min",
},
["-LTf"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "LTf",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["-STf"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "STf",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["dyn"] = {
name1 = "dyne",
symbol = "dyn",
utype = "force",
scale = 0.00001,
default = "gr-f",
},
["g-f"] = {
name1 = "gram-force",
name2 = "grams-force",
symbol = "g<sub>f</sub>",
utype = "force",
scale = 0.00980665,
default = "mN oz-f",
link = "Kilogram-force",
},
["gf"] = {
name1 = "gram-force",
name2 = "grams-force",
symbol = "gf",
utype = "force",
scale = 0.00980665,
default = "mN ozf",
link = "Kilogram-force",
},
["gr-f"] = {
name1 = "grain-force",
name2 = "grains-force",
symbol = "gr<sub>f</sub>",
utype = "force",
scale = 0.0006354602307515,
default = "μN",
link = "Pound (force)",
},
["grf"] = {
name1 = "grain-force",
name2 = "grains-force",
symbol = "grf",
utype = "force",
scale = 0.0006354602307515,
default = "μN",
link = "Pound (force)",
},
["kdyn"] = {
name1 = "kilodyne",
symbol = "kdyn",
utype = "force",
scale = 0.01,
default = "oz-f",
link = "Dyne",
},
["kg-f"] = {
name1 = "kilogram-force",
name2 = "kilograms-force",
symbol = "kg<sub>f</sub>",
utype = "force",
scale = 9.80665,
default = "N lb-f",
},
["kgf"] = {
name1 = "kilogram-force",
name2 = "kilograms-force",
symbol = "kgf",
utype = "force",
scale = 9.80665,
default = "N lbf",
},
["kp"] = {
name1 = "kilopond",
symbol = "kp",
utype = "force",
scale = 9.80665,
default = "N lb-f",
link = "Kilogram-force",
},
["L/T-f"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "L/T<sub>f</sub>",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["L/Tf"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "L/Tf",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["lb-f"] = {
name1 = "pound-force",
name2 = "pounds-force",
symbol = "lb<sub>f</sub>",
utype = "force",
scale = 4.4482216152605,
default = "N",
link = "Pound (force)",
},
["lbf"] = {
name1 = "pound-force",
name2 = "pounds-force",
symbol = "lbf",
utype = "force",
scale = 4.4482216152605,
default = "N",
link = "Pound (force)",
},
["lb(f)"] = {
name1 = "pound",
symbol = "lb",
utype = "force",
scale = 4.4482216152605,
default = "N",
link = "Pound (force)",
},
["LT-f"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "LT<sub>f</sub>",
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["LTf"] = {
name1 = "long ton-force",
name2 = "long tons-force",
symbol = "LTf",
usename = 1,
utype = "force",
scale = 9964.01641818352,
default = "kN",
},
["Mdyn"] = {
name1 = "megadyne",
symbol = "Mdyn",
utype = "force",
scale = 10,
default = "lb-f",
link = "Dyne",
},
["mdyn"] = {
name1 = "millidyne",
symbol = "mdyn",
utype = "force",
scale = 0.00000001,
default = "gr-f",
link = "Dyne",
},
["mg-f"] = {
name1 = "milligram-force",
name2 = "milligrams-force",
symbol = "mg<sub>f</sub>",
utype = "force",
scale = 0.00000980665,
default = "μN gr-f",
link = "Kilogram-force",
},
["mgf"] = {
name1 = "milligram-force",
name2 = "milligrams-force",
symbol = "mgf",
utype = "force",
scale = 0.00000980665,
default = "μN grf",
link = "Kilogram-force",
},
["Mp"] = {
name1 = "megapond",
symbol = "Mp",
utype = "force",
scale = 9806.65,
default = "kN LT-f ST-f",
link = "Kilogram-force",
},
["mp"] = {
name1 = "millipond",
symbol = "mp",
utype = "force",
scale = 0.00000980665,
default = "μN gr-f",
link = "Kilogram-force",
},
["N"] = {
_name1 = "newton",
_symbol = "N",
utype = "force",
scale = 1,
prefixes = 1,
default = "lb-f",
link = "Newton (unit)",
},
["oz-f"] = {
name1 = "ounce-force",
name2 = "ounces-force",
symbol = "oz<sub>f</sub>",
utype = "force",
scale = 0.2780138203095378125,
default = "mN",
link = "Pound (force)",
},
["ozf"] = {
name1 = "ounce-force",
name2 = "ounces-force",
symbol = "ozf",
utype = "force",
scale = 0.2780138203095378125,
default = "mN",
link = "Pound (force)",
},
["p"] = {
name1 = "pond",
symbol = "p",
utype = "force",
scale = 0.00980665,
default = "mN oz-f",
link = "Kilogram-force",
},
["pdl"] = {
name1 = "poundal",
symbol = "pdl",
utype = "force",
scale = 0.138254954376,
default = "N",
},
["S/T-f"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "S/T<sub>f</sub>",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["S/Tf"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "S/Tf",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["ST-f"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "ST<sub>f</sub>",
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["STf"] = {
name1 = "short ton-force",
name2 = "short tons-force",
symbol = "STf",
usename = 1,
utype = "force",
scale = 8896.443230521,
default = "kN",
},
["t-f"] = {
name1 = "tonne-force",
name2 = "tonnes-force",
symbol = "t<sub>f</sub>",
utype = "force",
scale = 9806.65,
default = "kN LT-f ST-f",
link = "Ton-force#Tonne-force",
},
["tf"] = {
name1 = "tonne-force",
name2 = "tonnes-force",
symbol = "tf",
utype = "force",
scale = 9806.65,
default = "kN LTf STf",
link = "Ton-force#Tonne-force",
},
["dyne"] = {
target = "dyn",
},
["newtons"] = {
target = "N",
},
["poundal"] = {
target = "pdl",
},
["tonne-force"] = {
target = "tf",
},
["impgal/mi"] = {
per = { "@impgal", "mi" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "L/km USgal/mi",
},
["km/L"] = {
per = { "km", "L" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "mpgimp mpgus",
},
["km/l"] = {
per = { "km", "ll" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "mpgimp mpgus",
},
["L/100 km"] = {
per = { "L", "100km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
symlink = "[[Fuel economy in automobiles#Units of measure|L/100 km]]",
},
["l/100 km"] = {
per = { "ll", "100km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
symlink = "[[Fuel economy in automobiles#Units of measure|l/100 km]]",
},
["L/km"] = {
per = { "L", "km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
},
["l/km"] = {
per = { "ll", "km" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "mpgimp mpgus",
},
["mi/impqt"] = {
per = { "mi", "impqt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mi/U.S.qt"] = {
per = { "mi", "U.S.qt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mi/USqt"] = {
per = { "mi", "USqt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mi/usqt"] = {
per = { "mi", "usqt" },
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "km/L",
},
["mpgimp"] = {
per = { "mi", "@impgal" },
symbol = "mpg<sub>‑imp</sub>",
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "L/100 km+mpgus",
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[Imperial units|imp]]</sub>",
},
["mpgus"] = {
per = { "mi", "+USgal" },
symbol = "mpg<sub>‑US</sub>",
utype = "fuel efficiency",
invert = -1,
iscomplex= true,
default = "L/100 km+mpgimp",
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[United States customary units|US]]</sub>",
},
["U.S.gal/mi"] = {
per = { "*U.S.gal", "mi" },
sp_us = true,
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "L/km impgal/mi",
},
["usgal/mi"] = {
per = { "+USgal", "mi" },
utype = "fuel efficiency",
invert = 1,
iscomplex= true,
default = "L/km impgal/mi",
},
["L/100km"] = {
target = "L/100 km",
},
["l/100km"] = {
target = "l/100 km",
},
["mpg"] = {
shouldbe = "Use %{mpgus%} for miles per US gallon or %{mpgimp%} for miles per imperial gallon (not %{mpg%})",
},
["mpgU.S."] = {
target = "mpgus",
symbol = "mpg<sub>‑U.S.</sub>",
sp_us = true,
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[United States customary units|U.S.]]</sub>",
},
["mpgu.s."] = {
target = "mpgus",
symbol = "mpg<sub>‑U.S.</sub>",
sp_us = true,
symlink = "[[Fuel economy in automobiles#Units of measure|mpg]]<sub>‑[[United States customary units|U.S.]]</sub>",
},
["mpgUS"] = {
target = "mpgus",
},
["USgal/mi"] = {
target = "usgal/mi",
},
["kPa/m"] = {
per = { "kPa", "-m-frac" },
utype = "fracture gradient",
default = "psi/ft",
},
["psi/ft"] = {
per = { "psi", "-ft-frac" },
utype = "fracture gradient",
default = "kPa/m",
},
["cm/km"] = {
name1 = "centimetre per kilometre",
name1_us = "centimeter per kilometer",
name2 = "centimetres per kilometre",
name2_us = "centimeters per kilometer",
symbol = "cm/km",
utype = "gradient",
scale = 0.00001,
default = "ft/mi",
link = "Grade (slope)",
},
["ft/mi"] = {
name1 = "foot per mile",
name2 = "feet per mile",
symbol = "ft/mi",
utype = "gradient",
scale = 0.00018939393939393939,
default = "v < 5.28 ! c ! ! m/km",
link = "Grade (slope)",
},
["ft/nmi"] = {
name1 = "foot per nautical mile",
name2 = "feet per nautical mile",
symbol = "ft/nmi",
utype = "gradient",
scale = 0.00016457883369330455,
default = "v < 6.076 ! c ! ! m/km",
link = "Grade (slope)",
},
["in/ft"] = {
name1 = "inch per foot",
name2 = "inches per foot",
symbol = "in/ft",
utype = "gradient",
scale = 0.083333333333333329,
default = "mm/m",
link = "Grade (slope)",
},
["in/mi"] = {
name1 = "inch per mile",
name2 = "inches per mile",
symbol = "in/mi",
utype = "gradient",
scale = 1.5782828282828283e-5,
default = "v < 0.6336 ! m ! c ! m/km",
link = "Grade (slope)",
},
["m/km"] = {
name1 = "metre per kilometre",
name1_us = "meter per kilometer",
name2 = "metres per kilometre",
name2_us = "meters per kilometer",
symbol = "m/km",
utype = "gradient",
scale = 0.001,
default = "ft/mi",
link = "Grade (slope)",
},
["mm/km"] = {
name1 = "millimetre per kilometre",
name1_us = "millimeter per kilometer",
name2 = "millimetres per kilometre",
name2_us = "millimeters per kilometer",
symbol = "mm/km",
utype = "gradient",
scale = 0.000001,
default = "in/mi",
link = "Grade (slope)",
},
["mm/m"] = {
name1 = "millimetre per metre",
name1_us = "millimeter per meter",
name2 = "millimetres per metre",
name2_us = "millimeters per meter",
symbol = "mm/m",
utype = "gradient",
scale = 0.001,
default = "in/ft",
link = "Grade (slope)",
},
["admi"] = {
name1 = "admiralty mile",
symbol = "nmi (admiralty)",
utype = "length",
scale = 1853.184,
default = "km mi",
link = "Nautical mile",
},
["AU"] = {
name1 = "astronomical unit",
symbol = "AU",
utype = "length",
scale = 149597870700,
default = "km mi",
},
["Brnmi"] = {
name1 = "British nautical mile",
symbol = "(Brit) nmi",
utype = "length",
scale = 1853.184,
default = "km mi",
link = "Nautical mile",
},
["bu"] = {
name2 = "bu",
symbol = "bu",
usename = 1,
utype = "length",
scale = 0.0030303030303030303,
default = "mm",
link = "Japanese units of measurement#Length",
},
["ch"] = {
name1 = "chain",
symbol = "ch",
utype = "length",
scale = 20.1168,
default = "ft m",
subdivs = { ["ft"] = { 66, default = "m" }, ["yd"] = { 22, default = "m" } },
link = "Chain (unit)",
},
["chlk"] = {
name1 = "[[Chain (unit)|chain]]",
symbol = "[[Chain (unit)|ch]]",
utype = "length",
scale = 20.1168,
default = "ft m",
link = "",
},
["chain"] = {
symbol = "chain",
usename = 1,
utype = "length",
scale = 20.1168,
default = "ft m",
subdivs = { ["ft"] = { 66, default = "m" }, ["yd"] = { 22, default = "m" } },
link = "Chain (unit)",
},
["chainlk"] = {
symbol = "[[Chain (unit)|chain]]",
usename = 1,
utype = "length",
scale = 20.1168,
default = "ft m",
link = "",
},
["dpcm"] = {
name2 = "dot/cm",
symbol = "dot/cm",
utype = "length",
scale = 100,
invert = -1,
iscomplex= true,
default = "dpi",
link = "Dots per inch",
},
["dpi"] = {
name2 = "DPI",
symbol = "DPI",
utype = "length",
scale = 39.370078740157481,
invert = -1,
iscomplex= true,
default = "pitch",
link = "Dots per inch",
},
["fathom"] = {
symbol = "fathom",
usename = 1,
utype = "length",
scale = 1.8288,
default = "ft m",
},
["foot"] = {
name1 = "foot",
name2 = "foot",
symbol = "ft",
utype = "length",
scale = 0.3048,
default = "m",
subdivs = { ["in"] = { 12, default = "m" } },
link = "Foot (unit)",
},
["ft"] = {
name1 = "foot",
name2 = "feet",
symbol = "ft",
utype = "length",
scale = 0.3048,
exception= "integer_more_precision",
default = "m",
subdivs = { ["in"] = { 12, default = "m" } },
link = "Foot (unit)",
},
["furlong"] = {
symbol = "furlong",
usename = 1,
utype = "length",
scale = 201.168,
default = "ft m",
},
["Gly"] = {
name1 = "gigalight-year",
symbol = "Gly",
utype = "length",
scale = 9.4607304725808e24,
default = "Mpc",
link = "Light-year#Definitions",
},
["Gpc"] = {
name1 = "gigaparsec",
symbol = "Gpc",
utype = "length",
scale = 3.0856775814671916e25,
default = "Gly",
link = "Parsec#Megaparsecs and gigaparsecs",
},
["hand"] = {
name1 = "hand",
symbol = "h",
utype = "length",
builtin = "hand",
scale = 0.1016,
iscomplex= true,
default = "in cm",
link = "Hand (unit)",
},
["in"] = {
name1 = "inch",
name2 = "inches",
symbol = "in",
utype = "length",
scale = 0.0254,
exception= "subunit_more_precision",
default = "mm",
},
["inabbreviated"] = {
name2 = "in",
symbol = "in",
utype = "length",
scale = 0.0254,
default = "mm",
link = "Inch",
},
["kly"] = {
name1 = "kilolight-year",
symbol = "kly",
utype = "length",
scale = 9.4607304725808e18,
default = "pc",
link = "Light-year#Definitions",
},
["kpc"] = {
name1 = "kiloparsec",
symbol = "kpc",
utype = "length",
scale = 3.0856775814671916e19,
default = "kly",
link = "Parsec#Parsecs and kiloparsecs",
},
["LD"] = {
name1 = "lunar distance",
symbol = "LD",
utype = "length",
scale = 384403000,
default = "km mi",
link = "Lunar distance (astronomy)",
},
["league"] = {
symbol = "league",
usename = 1,
utype = "length",
scale = 4828.032,
default = "km",
link = "League (unit)",
},
["ly"] = {
name1 = "light-year",
symbol = "ly",
utype = "length",
scale = 9.4607304725808e15,
default = "AU",
},
["m"] = {
_name1 = "metre",
_name1_us= "meter",
_symbol = "m",
utype = "length",
scale = 1,
prefixes = 1,
default = "v > 0 and v < 3 ! ftin ! ft",
link = "Metre",
},
["mi"] = {
name1 = "mile",
symbol = "mi",
utype = "length",
scale = 1609.344,
default = "km",
subdivs = { ["ch"] = { 80, default = "km" }, ["chlk"] = { 80, default = "km" }, ["chain"] = { 80, default = "km" }, ["chainlk"] = { 80, default = "km" }, ["ft"] = { 5280, default = "km" }, ["furlong"] = { 8, default = "km" }, ["yd"] = { 1760, default = "km" } },
},
["mil"] = {
symbol = "mil",
usename = 1,
utype = "length",
scale = 0.0000254,
default = "mm",
link = "Thousandth of an inch",
},
["Mly"] = {
name1 = "megalight-year",
symbol = "Mly",
utype = "length",
scale = 9.4607304725808e21,
default = "kpc",
link = "Light-year#Definitions",
},
["Mpc"] = {
name1 = "megaparsec",
symbol = "Mpc",
utype = "length",
scale = 3.0856775814671916e22,
default = "Mly",
link = "Parsec#Megaparsecs and gigaparsecs",
},
["NM"] = {
name1 = "nautical mile",
symbol = "NM",
utype = "length",
scale = 1852,
default = "km mi",
},
["nmi"] = {
name1 = "nautical mile",
symbol = "nmi",
utype = "length",
scale = 1852,
default = "km mi",
},
["oldUKnmi"] = {
name1 = "nautical mile",
symbol = "nmi",
utype = "length",
scale = 1853.184,
default = "km mi",
},
["oldUSnmi"] = {
name1 = "nautical mile",
symbol = "nmi",
utype = "length",
scale = 1853.24496,
default = "km mi",
},
["pc"] = {
name1 = "parsec",
symbol = "pc",
utype = "length",
scale = 3.0856775814671916e16,
default = "ly",
},
["perch"] = {
name2 = "perches",
symbol = "perch",
usename = 1,
utype = "length",
scale = 5.0292,
default = "ft m",
link = "Rod (unit)",
},
["pitch"] = {
name2 = "μm",
symbol = "μm",
utype = "length",
scale = 1e-6,
default = "dpi",
defkey = "pitch",
linkey = "pitch",
link = "Dots per inch",
},
["pole"] = {
symbol = "pole",
usename = 1,
utype = "length",
scale = 5.0292,
default = "ft m",
link = "Rod (unit)",
},
["pre1954U.S.nmi"] = {
name1 = "(pre-1954 U.S.) nautical mile",
symbol = "(pre‑1954 U.S.) nmi",
utype = "length",
scale = 1853.24496,
default = "km mi",
link = "Nautical mile",
},
["pre1954USnmi"] = {
name1 = "(pre-1954 US) nautical mile",
name1_us = "(pre-1954 U.S.) nautical mile",
symbol = "(pre‑1954 US) nmi",
sym_us = "(pre‑1954 U.S.) nmi",
utype = "length",
scale = 1853.24496,
default = "km mi",
link = "Nautical mile",
},
["rd"] = {
name1 = "rod",
symbol = "rd",
utype = "length",
scale = 5.0292,
default = "ft m",
link = "Rod (unit)",
},
["royal cubit"] = {
name1 = "royal cubit",
symbol = "cu",
utype = "length",
scale = 0.524,
default = "mm",
},
["rtkm"] = {
name1 = "route kilometre",
name1_us = "route kilometer",
symbol = "km",
utype = "length",
scale = 1000,
default = "mi",
link = "Kilometre",
},
["rtmi"] = {
name1 = "route mile",
symbol = "mi",
utype = "length",
scale = 1609.344,
default = "km",
link = "Mile",
},
["shaku"] = {
name2 = "shaku",
symbol = "shaku",
usename = 1,
utype = "length",
scale = 0.30303030303030304,
default = "m",
link = "Shaku (unit)",
},
["sm"] = {
name1 = "smoot",
symbol = "sm",
utype = "length",
scale = 1.70180,
default = "m",
link = "Smoot (unit)",
},
["smi"] = {
name1 = "statute mile",
symbol = "mi",
utype = "length",
scale = 1609.344,
default = "km",
subdivs = { ["chain"] = { 80, default = "km" } },
},
["solar radius"] = {
name1 = "solar radius",
name2 = "solar radii",
symbol = "''R''<sub>☉</sub>",
utype = "length",
scale = 695700e3,
default = "km",
},
["sun"] = {
name2 = "sun",
symbol = "sun",
usename = 1,
utype = "length",
scale = 0.030303030303030304,
default = "mm",
link = "Japanese units of measurement#Length",
},
["thou"] = {
name2 = "thou",
symbol = "thou",
usename = 1,
utype = "length",
scale = 0.0000254,
default = "mm",
link = "Thousandth of an inch",
},
["verst"] = {
symbol = "verst",
usename = 1,
utype = "length",
scale = 1066.8,
default = "km mi",
},
["yd"] = {
name1 = "yard",
symbol = "yd",
utype = "length",
scale = 0.9144,
default = "m",
subdivs = { ["ft"] = { 3, default = "m" } },
},
["μin"] = {
name1 = "microinch",
name2 = "microinches",
symbol = "μin",
utype = "length",
scale = 0.0000000254,
default = "nm",
link = "SI prefix#Non-metric units",
},
["Å"] = {
name1 = "ångström",
symbol = "Å",
utype = "length",
scale = 0.0000000001,
default = "in",
},
["Hz"] = {
_name1 = "hertz",
_name2 = "hertz",
_symbol = "Hz",
utype = "length",
scale = 3.3356409519815204e-9,
invert = -1,
iscomplex= true,
prefixes = 1,
default = "m",
link = "Hertz",
},
["rpm"] = {
name1 = "revolution per minute",
name2 = "revolutions per minute",
symbol = "rpm",
utype = "length",
scale = 5.5594015866358675e-11,
invert = -1,
iscomplex= true,
default = "Hz",
link = "Revolutions per minute",
},
["-ft-frac"] = {
target = "ft",
link = "Fracture gradient",
},
["-in-stiff"] = {
target = "in",
link = "Stiffness",
},
["-m-frac"] = {
target = "m",
link = "Fracture gradient",
},
["-m-stiff"] = {
target = "m",
link = "Stiffness",
},
["100km"] = {
target = "km",
multiplier= 100,
},
["100mi"] = {
target = "mi",
multiplier= 100,
},
["100miles"] = {
target = "mi",
symbol = "miles",
multiplier= 100,
},
["admiralty nmi"] = {
target = "oldUKnmi",
},
["angstrom"] = {
target = "Å",
},
["au"] = {
target = "AU",
symbol = "au",
},
["feet"] = {
target = "ft",
},
["hands"] = {
target = "hand",
},
["inch"] = {
target = "in",
},
["inches"] = {
target = "in",
},
["light-year"] = {
target = "ly",
},
["meter"] = {
target = "m",
sp_us = true,
},
["meters"] = {
target = "m",
sp_us = true,
},
["metre"] = {
target = "m",
},
["metres"] = {
target = "m",
},
["micrometre"] = {
target = "μm",
},
["micron"] = {
target = "μm",
default = "μin",
},
["mile"] = {
target = "mi",
usename = 1,
},
["miles"] = {
target = "mi",
usename = 1,
},
["parsec"] = {
target = "pc",
},
["rod"] = {
target = "rd",
},
["smoot"] = {
target = "sm",
},
["uin"] = {
target = "μin",
},
["yard"] = {
target = "yd",
},
["yards"] = {
target = "yd",
},
["yds"] = {
target = "yd",
},
["dtex"] = {
name1 = "decitex",
name2 = "decitex",
symbol = "dtex",
utype = "linear density",
scale = 1e-7,
default = "lb/yd",
link = "Units of textile measurement#Units",
},
["kg/cm"] = {
name1 = "kilogram per centimetre",
name1_us = "kilogram per centimeter",
name2 = "kilograms per centimetre",
name2_us = "kilograms per centimeter",
symbol = "kg/cm",
utype = "linear density",
scale = 100,
default = "lb/yd",
link = "Linear density",
},
["kg/m"] = {
name1 = "kilogram per metre",
name1_us = "kilogram per meter",
name2 = "kilograms per metre",
name2_us = "kilograms per meter",
symbol = "kg/m",
utype = "linear density",
scale = 1,
default = "lb/yd",
link = "Linear density",
},
["lb/ft"] = {
name1 = "pound per foot",
name2 = "pounds per foot",
symbol = "lb/ft",
utype = "linear density",
scale = 1.4881639435695539,
default = "kg/m",
link = "Linear density",
},
["lb/yd"] = {
name1 = "pound per yard",
name2 = "pounds per yard",
symbol = "lb/yd",
utype = "linear density",
scale = 0.49605464785651798,
default = "kg/m",
link = "Linear density",
},
["G"] = {
_name1 = "gauss",
_name2 = "gauss",
_symbol = "G",
utype = "magnetic field strength",
scale = 0.0001,
prefixes = 1,
default = "T",
link = "Gauss (unit)",
},
["T"] = {
_name1 = "tesla",
_symbol = "T",
utype = "magnetic field strength",
scale = 1,
prefixes = 1,
default = "G",
link = "Tesla (unit)",
},
["A/m"] = {
name1 = "ampere per metre",
name1_us = "ampere per meter",
name2 = "amperes per metre",
name2_us = "amperes per meter",
symbol = "A/m",
utype = "magnetizing field",
scale = 1,
default = "Oe",
},
["kA/m"] = {
name1 = "kiloampere per metre",
name1_us = "kiloampere per meter",
name2 = "kiloamperes per metre",
name2_us = "kiloamperes per meter",
symbol = "kA/m",
utype = "magnetizing field",
scale = 1000,
default = "kOe",
link = "Ampere per metre",
},
["MA/m"] = {
name1 = "megaampere per metre",
name1_us = "megaampere per meter",
name2 = "megaamperes per metre",
name2_us = "megaamperes per meter",
symbol = "MA/m",
utype = "magnetizing field",
scale = 1e6,
default = "kOe",
link = "Ampere per metre",
},
["Oe"] = {
_name1 = "oersted",
_symbol = "Oe",
utype = "magnetizing field",
scale = 79.5774715,
prefixes = 1,
default = "kA/m",
link = "Oersted",
},
["-Lcwt"] = {
name1 = "hundredweight",
name2 = "hundredweight",
symbol = "cwt",
utype = "mass",
scale = 50.80234544,
default = "lb",
},
["-Scwt"] = {
name1 = "hundredweight",
name2 = "hundredweight",
symbol = "cwt",
utype = "mass",
scale = 45.359237,
default = "lb",
},
["-ST"] = {
name1 = "short ton",
symbol = "ST",
utype = "mass",
scale = 907.18474,
default = "t",
},
["carat"] = {
symbol = "carat",
usename = 1,
utype = "mass",
scale = 0.0002,
default = "g",
link = "Carat (mass)",
},
["drachm"] = {
name1_us = "dram",
symbol = "drachm",
usename = 1,
utype = "mass",
scale = 0.001771845195,
default = "g",
link = "Dram (unit)",
},
["dram"] = {
target = "drachm",
},
["dwt"] = {
name1 = "pennyweight",
symbol = "dwt",
utype = "mass",
scale = 0.00155517384,
default = "oz g",
},
["DWton"] = {
symbol = "deadweight ton",
usename = 1,
utype = "mass",
scale = 1016.0469088,
default = "DWtonne",
link = "Deadweight tonnage",
},
["DWtonne"] = {
name1_us = "deadweight metric ton",
symbol = "deadweight tonne",
sym_us = "~deadweight metric ton",
usename = 1,
utype = "mass",
scale = 1000,
default = "DWton",
link = "Deadweight tonnage",
},
["g"] = {
_name1 = "gram",
_symbol = "g",
utype = "mass",
scale = 0.001,
prefixes = 1,
default = "oz",
link = "Gram",
},
["gr"] = {
name1 = "grain",
symbol = "gr",
utype = "mass",
scale = 0.00006479891,
default = "g",
link = "Grain (unit)",
},
["Gt"] = {
name1 = "gigatonne",
symbol = "Gt",
utype = "mass",
scale = 1000000000000,
default = "LT ST",
link = "Tonne",
},
["impgalh2o"] = {
name1 = "imperial gallon of water",
name2 = "imperial gallons of water",
symbol = "imp gal H<sub>2</sub>O",
utype = "mass",
scale = 4.5359236999999499,
default = "lb kg",
link = "Imperial gallon",
},
["kt"] = {
name1 = "kilotonne",
symbol = "kt",
utype = "mass",
scale = 1000000,
default = "LT ST",
link = "Tonne",
},
["lb"] = {
name1 = "pound",
symbol = "lb",
utype = "mass",
scale = 0.45359237,
exception= "integer_more_precision",
default = "kg",
subdivs = { ["oz"] = { 16, default = "kg" } },
link = "Pound (mass)",
},
["Lcwt"] = {
name1 = "long hundredweight",
name2 = "long hundredweight",
symbol = "Lcwt",
usename = 1,
utype = "mass",
scale = 50.80234544,
default = "lb",
subdivs = { ["qtr"] = { 4, default = "kg" }, ["st"] = { 8, default = "kg" } },
link = "Hundredweight",
},
["long cwt"] = {
name1 = "long hundredweight",
name2 = "long hundredweight",
symbol = "long cwt",
utype = "mass",
scale = 50.80234544,
default = "lb kg",
subdivs = { ["qtr"] = { 4, default = "kg" } },
link = "Hundredweight",
},
["long qtr"] = {
name1 = "long quarter",
symbol = "long qtr",
utype = "mass",
scale = 12.70058636,
default = "lb kg",
},
["LT"] = {
symbol = "long ton",
usename = 1,
utype = "mass",
scale = 1016.0469088,
default = "t",
subdivs = { ["Lcwt"] = { 20, default = "t", unit = "-Lcwt" } },
},
["lt"] = {
name1 = "long ton",
symbol = "LT",
utype = "mass",
scale = 1016.0469088,
default = "t",
subdivs = { ["Lcwt"] = { 20, default = "t", unit = "-Lcwt" } },
},
["metric ton"] = {
symbol = "metric ton",
usename = 1,
utype = "mass",
scale = 1000,
default = "long ton",
link = "Tonne",
},
["MT"] = {
name1 = "metric ton",
symbol = "t",
utype = "mass",
scale = 1000,
default = "LT ST",
link = "Tonne",
},
["Mt"] = {
name1 = "megatonne",
symbol = "Mt",
utype = "mass",
scale = 1000000000,
default = "LT ST",
link = "Tonne",
},
["oz"] = {
name1 = "ounce",
symbol = "oz",
utype = "mass",
scale = 0.028349523125,
default = "g",
},
["ozt"] = {
name1 = "troy ounce",
symbol = "ozt",
utype = "mass",
scale = 0.0311034768,
default = "oz g",
},
["pdr"] = {
name1 = "pounder",
symbol = "pdr",
utype = "mass",
scale = 0.45359237,
default = "kg",
link = "Pound (mass)",
},
["qtr"] = {
name1 = "quarter",
symbol = "qtr",
utype = "mass",
scale = 12.70058636,
default = "lb kg",
subdivs = { ["lb"] = { 28, default = "kg" } },
link = "Long quarter",
},
["Scwt"] = {
name1 = "short hundredweight",
name2 = "short hundredweight",
symbol = "Scwt",
usename = 1,
utype = "mass",
scale = 45.359237,
default = "lb",
link = "Hundredweight",
},
["short cwt"] = {
name1 = "short hundredweight",
name2 = "short hundredweight",
symbol = "short cwt",
utype = "mass",
scale = 45.359237,
default = "lb kg",
link = "Hundredweight",
},
["short qtr"] = {
name1 = "short quarter",
symbol = "short qtr",
utype = "mass",
scale = 11.33980925,
default = "lb kg",
},
["ST"] = {
symbol = "short ton",
usename = 1,
utype = "mass",
scale = 907.18474,
default = "t",
subdivs = { ["Scwt"] = { 20, default = "t", unit = "-Scwt" } },
},
["shtn"] = {
name1 = "short ton",
symbol = "sh tn",
utype = "mass",
scale = 907.18474,
default = "t",
},
["shton"] = {
symbol = "ton",
usename = 1,
utype = "mass",
scale = 907.18474,
default = "t",
},
["solar mass"] = {
name1 = "solar mass",
name2 = "solar masses",
symbol = "''M''<sub>☉</sub>",
utype = "mass",
scale = 1.98855e30,
default = "kg",
},
["st"] = {
name1 = "stone",
name2 = "stone",
symbol = "st",
utype = "mass",
scale = 6.35029318,
default = "lb kg",
subdivs = { ["lb"] = { 14, default = "kg lb" } },
link = "Stone (unit)",
},
["t"] = {
name1 = "tonne",
name1_us = "metric ton",
symbol = "t",
utype = "mass",
scale = 1000,
default = "LT ST",
},
["tonne"] = {
name1 = "tonne",
name1_us = "metric ton",
symbol = "t",
utype = "mass",
scale = 1000,
default = "shton",
},
["troy pound"] = {
symbol = "troy pound",
usename = 1,
utype = "mass",
scale = 0.3732417216,
default = "lb kg",
link = "Troy weight",
},
["usgalh2o"] = {
name1 = "US gallon of water",
name1_us = "U.S. gallon of water",
name2 = "US gallons of water",
name2_us = "U.S. gallons of water",
symbol = "US gal H<sub>2</sub>O",
utype = "mass",
scale = 3.7776215836051126,
default = "lb kg",
link = "United States customary units#Fluid volume",
},
["viss"] = {
name2 = "viss",
symbol = "viss",
utype = "mass",
scale = 1.632932532,
default = "kg",
link = "Myanmar units of measurement#Mass",
},
["billion tonne"] = {
target = "e9t",
},
["kilogram"] = {
target = "kg",
},
["kilotonne"] = {
target = "kt",
},
["lbs"] = {
target = "lb",
},
["lbt"] = {
target = "troy pound",
},
["lcwt"] = {
target = "Lcwt",
},
["long ton"] = {
target = "LT",
},
["mcg"] = {
target = "μg",
},
["million tonne"] = {
target = "e6t",
},
["scwt"] = {
target = "Scwt",
},
["short ton"] = {
target = "ST",
},
["stone"] = {
target = "st",
},
["thousand tonne"] = {
target = "e3t",
},
["tonnes"] = {
target = "t",
},
["kg/kW"] = {
name1 = "kilogram per kilowatt",
name2 = "kilograms per kilowatt",
symbol = "kg/kW",
utype = "mass per unit power",
scale = 0.001,
default = "lb/hp",
link = "Kilowatt",
},
["lb/hp"] = {
name1 = "pound per horsepower",
name2 = "pounds per horsepower",
symbol = "lb/hp",
utype = "mass per unit power",
scale = 0.00060827738784176115,
default = "kg/kW",
link = "Horsepower",
},
["kg/h"] = {
per = { "kg", "h" },
utype = "mass per unit time",
default = "lb/h",
},
["lb/h"] = {
per = { "lb", "h" },
utype = "mass per unit time",
default = "kg/h",
},
["g-mol/d"] = {
name1 = "gram-mole per day",
name2 = "gram-moles per day",
symbol = "g‑mol/d",
utype = "molar rate",
scale = 1.1574074074074073e-5,
default = "μmol/s",
link = "Mole (unit)",
},
["g-mol/h"] = {
name1 = "gram-mole per hour",
name2 = "gram-moles per hour",
symbol = "g‑mol/h",
utype = "molar rate",
scale = 0.00027777777777777778,
default = "mmol/s",
link = "Mole (unit)",
},
["g-mol/min"] = {
name1 = "gram-mole per minute",
name2 = "gram-moles per minute",
symbol = "g‑mol/min",
utype = "molar rate",
scale = 0.016666666666666666,
default = "g-mol/s",
link = "Mole (unit)",
},
["g-mol/s"] = {
name1 = "gram-mole per second",
name2 = "gram-moles per second",
symbol = "g‑mol/s",
utype = "molar rate",
scale = 1,
default = "lb-mol/min",
link = "Mole (unit)",
},
["gmol/d"] = {
name1 = "gram-mole per day",
name2 = "gram-moles per day",
symbol = "gmol/d",
utype = "molar rate",
scale = 1.1574074074074073e-5,
default = "μmol/s",
link = "Mole (unit)",
},
["gmol/h"] = {
name1 = "gram-mole per hour",
name2 = "gram-moles per hour",
symbol = "gmol/h",
utype = "molar rate",
scale = 0.00027777777777777778,
default = "mmol/s",
link = "Mole (unit)",
},
["gmol/min"] = {
name1 = "gram-mole per minute",
name2 = "gram-moles per minute",
symbol = "gmol/min",
utype = "molar rate",
scale = 0.016666666666666666,
default = "gmol/s",
link = "Mole (unit)",
},
["gmol/s"] = {
name1 = "gram-mole per second",
name2 = "gram-moles per second",
symbol = "gmol/s",
utype = "molar rate",
scale = 1,
default = "lbmol/min",
link = "Mole (unit)",
},
["kmol/d"] = {
name1 = "kilomole per day",
name2 = "kilomoles per day",
symbol = "kmol/d",
utype = "molar rate",
scale = 0.011574074074074073,
default = "mmol/s",
link = "Mole (unit)",
},
["kmol/h"] = {
name1 = "kilomole per hour",
name2 = "kilomoles per hour",
symbol = "kmol/h",
utype = "molar rate",
scale = 0.27777777777777779,
default = "mol/s",
link = "Mole (unit)",
},
["kmol/min"] = {
name1 = "kilomole per minute",
name2 = "kilomoles per minute",
symbol = "kmol/min",
utype = "molar rate",
scale = 16.666666666666668,
default = "mol/s",
link = "Kilomole (unit)",
},
["kmol/s"] = {
name1 = "kilomole per second",
name2 = "kilomoles per second",
symbol = "kmol/s",
utype = "molar rate",
scale = 1000,
default = "lb-mol/s",
link = "Mole (unit)",
},
["lb-mol/d"] = {
name1 = "pound-mole per day",
name2 = "pound-moles per day",
symbol = "lb‑mol/d",
utype = "molar rate",
scale = 0.0052499116898148141,
default = "mmol/s",
link = "Pound-mole",
},
["lb-mol/h"] = {
name1 = "pound-mole per hour",
name2 = "pound-moles per hour",
symbol = "lb‑mol/h",
utype = "molar rate",
scale = 0.12599788055555555,
default = "mol/s",
link = "Pound-mole",
},
["lb-mol/min"] = {
name1 = "pound-mole per minute",
name2 = "pound-moles per minute",
symbol = "lb‑mol/min",
utype = "molar rate",
scale = 7.5598728333333334,
default = "mol/s",
link = "Pound-mole",
},
["lb-mol/s"] = {
name1 = "pound-mole per second",
name2 = "pound-moles per second",
symbol = "lb‑mol/s",
utype = "molar rate",
scale = 453.59237,
default = "kmol/s",
link = "Pound-mole",
},
["lbmol/d"] = {
name1 = "pound-mole per day",
name2 = "pound-moles per day",
symbol = "lbmol/d",
utype = "molar rate",
scale = 0.0052499116898148141,
default = "mmol/s",
link = "Pound-mole",
},
["lbmol/h"] = {
name1 = "pound-mole per hour",
name2 = "pound-moles per hour",
symbol = "lbmol/h",
utype = "molar rate",
scale = 0.12599788055555555,
default = "mol/s",
link = "Pound-mole",
},
["lbmol/min"] = {
name1 = "pound-mole per minute",
name2 = "pound-moles per minute",
symbol = "lbmol/min",
utype = "molar rate",
scale = 7.5598728333333334,
default = "mol/s",
link = "Pound-mole",
},
["lbmol/s"] = {
name1 = "pound-mole per second",
name2 = "pound-moles per second",
symbol = "lbmol/s",
utype = "molar rate",
scale = 453.59237,
default = "kmol/s",
link = "Pound-mole",
},
["mmol/s"] = {
name1 = "millimole per second",
name2 = "millimoles per second",
symbol = "mmol/s",
utype = "molar rate",
scale = 0.001,
default = "lb-mol/d",
link = "Mole (unit)",
},
["mol/d"] = {
name1 = "mole per day",
name2 = "moles per day",
symbol = "mol/d",
utype = "molar rate",
scale = 1.1574074074074073e-5,
default = "μmol/s",
link = "Mole (unit)",
},
["mol/h"] = {
name1 = "mole per hour",
name2 = "moles per hour",
symbol = "mol/h",
utype = "molar rate",
scale = 0.00027777777777777778,
default = "mmol/s",
link = "Mole (unit)",
},
["mol/min"] = {
name1 = "mole per minute",
name2 = "moles per minute",
symbol = "mol/min",
utype = "molar rate",
scale = 0.016666666666666666,
default = "mol/s",
link = "Mole (unit)",
},
["mol/s"] = {
name1 = "mole per second",
name2 = "moles per second",
symbol = "mol/s",
utype = "molar rate",
scale = 1,
default = "lb-mol/min",
link = "Mole (unit)",
},
["μmol/s"] = {
name1 = "micromole per second",
name2 = "micromoles per second",
symbol = "μmol/s",
utype = "molar rate",
scale = 0.000001,
default = "lb-mol/d",
link = "Mole (unit)",
},
["umol/s"] = {
target = "μmol/s",
},
["/acre"] = {
name1 = "per acre",
name2 = "per acre",
symbol = "/acre",
utype = "per unit area",
scale = 0.00024710538146716532,
default = "/ha",
link = "Acre",
},
["/ha"] = {
name1 = "per hectare",
name2 = "per hectare",
symbol = "/ha",
utype = "per unit area",
scale = 100e-6,
default = "/acre",
link = "Hectare",
},
["/sqcm"] = {
name1 = "per square centimetre",
name1_us = "per square centimeter",
name2 = "per square centimetre",
name2_us = "per square centimeter",
symbol = "/cm<sup>2</sup>",
utype = "per unit area",
scale = 1e4,
default = "/sqin",
link = "Square centimetre",
},
["/sqin"] = {
name1 = "per square inch",
name2 = "per square inch",
symbol = "/in<sup>2</sup>",
utype = "per unit area",
scale = 1550.0031000062002,
default = "/sqcm",
link = "Square inch",
},
["/sqkm"] = {
name1 = "per square kilometre",
name1_us = "per square kilometer",
name2 = "per square kilometre",
name2_us = "per square kilometer",
symbol = "/km<sup>2</sup>",
utype = "per unit area",
scale = 1e-6,
default = "/sqmi",
link = "Square kilometre",
},
["/sqmi"] = {
name1 = "per square mile",
name2 = "per square mile",
symbol = "/sq mi",
utype = "per unit area",
scale = 3.8610215854244582e-7,
default = "/sqkm",
link = "Square mile",
},
["PD/acre"] = {
name1 = "inhabitant per acre",
name2 = "inhabitants per acre",
symbol = "/acre",
utype = "per unit area",
scale = 0.00024710538146716532,
default = "PD/ha",
link = "Acre",
},
["PD/ha"] = {
name1 = "inhabitant per hectare",
name2 = "inhabitants per hectare",
symbol = "/ha",
utype = "per unit area",
scale = 100e-6,
default = "PD/acre",
link = "Hectare",
},
["PD/sqkm"] = {
name1 = "inhabitant per square kilometre",
name1_us = "inhabitant per square kilometer",
name2 = "inhabitants per square kilometre",
name2_us = "inhabitants per square kilometer",
symbol = "/km<sup>2</sup>",
utype = "per unit area",
scale = 1e-6,
default = "PD/sqmi",
link = "Square kilometre",
},
["PD/sqmi"] = {
name1 = "inhabitant per square mile",
name2 = "inhabitants per square mile",
symbol = "/sq mi",
utype = "per unit area",
scale = 3.8610215854244582e-7,
default = "PD/sqkm",
link = "Square mile",
},
["/cm2"] = {
target = "/sqcm",
},
["/in2"] = {
target = "/sqin",
},
["/km2"] = {
target = "/sqkm",
},
["pd/acre"] = {
target = "PD/acre",
},
["pd/ha"] = {
target = "PD/ha",
},
["PD/km2"] = {
target = "PD/sqkm",
},
["pd/km2"] = {
target = "PD/sqkm",
},
["PD/km²"] = {
target = "PD/sqkm",
},
["pd/sqkm"] = {
target = "PD/sqkm",
},
["pd/sqmi"] = {
target = "PD/sqmi",
},
["/l"] = {
name1 = "per litre",
name1_us = "per liter",
name2 = "per litre",
name2_us = "per liter",
symbol = "/l",
utype = "per unit volume",
scale = 1000,
default = "/usgal",
link = "Litre",
},
["/L"] = {
name1 = "per litre",
name1_us = "per liter",
name2 = "per litre",
name2_us = "per liter",
symbol = "/L",
utype = "per unit volume",
scale = 1000,
default = "/usgal",
link = "Litre",
},
["/USgal"] = {
name1 = "per gallon",
name2 = "per gallon",
symbol = "/gal",
utype = "per unit volume",
scale = 264.172052,
default = "/L",
link = "US gallon",
customary= 2,
},
["/usgal"] = {
target = "/USgal",
},
["bhp"] = {
name1 = "brake horsepower",
name2 = "brake horsepower",
symbol = "bhp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
link = "Horsepower#Brake horsepower",
},
["Cal/d"] = {
name1 = "large calorie per day",
name2 = "large calories per day",
symbol = "Cal/d",
utype = "power",
scale = 0.048425925925925928,
default = "kJ/d",
link = "Calorie",
},
["Cal/h"] = {
name1 = "large calorie per hour",
name2 = "large calories per hour",
symbol = "Cal/h",
utype = "power",
scale = 1.1622222222222223,
default = "kJ/h",
link = "Calorie",
},
["cal/h"] = {
name1 = "calorie per hour",
name2 = "calories per hour",
symbol = "cal/h",
utype = "power",
scale = 0.0011622222222222223,
default = "W",
link = "Calorie",
},
["CV"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "CV",
utype = "power",
scale = 735.49875,
default = "kW",
},
["hk"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "hk",
utype = "power",
scale = 735.49875,
default = "kW",
},
["hp"] = {
name1 = "horsepower",
name2 = "horsepower",
symbol = "hp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
},
["hp-electric"] = {
name1 = "electric horsepower",
name2 = "electric horsepower",
symbol = "hp",
utype = "power",
scale = 746,
default = "kW",
link = "Horsepower#Electrical horsepower",
},
["hp-electrical"] = {
name1 = "electrical horsepower",
name2 = "electrical horsepower",
symbol = "hp",
utype = "power",
scale = 746,
default = "kW",
link = "Horsepower#Electrical horsepower",
},
["hp-metric"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "hp",
utype = "power",
scale = 735.49875,
default = "kW",
},
["ihp"] = {
name1 = "indicated horsepower",
name2 = "indicated horsepower",
symbol = "ihp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
link = "Horsepower#Indicated horsepower",
},
["kcal/h"] = {
name1 = "kilocalorie per hour",
name2 = "kilocalories per hour",
symbol = "kcal/h",
utype = "power",
scale = 1.1622222222222223,
default = "kW",
link = "Calorie",
},
["kJ/d"] = {
name1 = "kilojoule per day",
name2 = "kilojoules per day",
symbol = "kJ/d",
utype = "power",
scale = 0.011574074074074073,
default = "Cal/d",
link = "Kilojoule",
},
["kJ/h"] = {
name1 = "kilojoule per hour",
name2 = "kilojoules per hour",
symbol = "kJ/h",
utype = "power",
scale = 0.27777777777777779,
default = "W",
link = "Kilojoule",
},
["PS"] = {
name1 = "metric horsepower",
name2 = "metric horsepower",
symbol = "PS",
utype = "power",
scale = 735.49875,
default = "kW",
},
["shp"] = {
name1 = "shaft horsepower",
name2 = "shaft horsepower",
symbol = "shp",
utype = "power",
scale = 745.69987158227022,
default = "kW",
link = "Horsepower#Shaft horsepower",
},
["W"] = {
_name1 = "watt",
_symbol = "W",
utype = "power",
scale = 1,
prefixes = 1,
default = "hp",
link = "Watt",
},
["BTU/h"] = {
per = { "BTU", "h" },
utype = "power",
default = "W",
},
["Btu/h"] = {
per = { "Btu", "h" },
utype = "power",
default = "W",
},
["BHP"] = {
target = "bhp",
},
["btu/h"] = {
target = "BTU/h",
},
["HP"] = {
target = "hp",
},
["Hp"] = {
target = "hp",
},
["hp-mechanical"] = {
target = "hp",
},
["IHP"] = {
target = "ihp",
},
["SHP"] = {
target = "shp",
},
["whp"] = {
target = "hp",
},
["hp/lb"] = {
name1 = "horsepower per pound",
name2 = "horsepower per pound",
symbol = "hp/lb",
utype = "power per unit mass",
scale = 1643.986806,
default = "kW/kg",
link = "Power-to-weight ratio",
},
["hp/LT"] = {
name1 = "horsepower per long ton",
name2 = "horsepower per long ton",
symbol = "hp/LT",
utype = "power per unit mass",
scale = 0.73392268125000004,
default = "kW/t",
link = "Power-to-weight ratio",
},
["hp/ST"] = {
name1 = "horsepower per short ton",
name2 = "horsepower per short ton",
symbol = "hp/ST",
utype = "power per unit mass",
scale = 0.821993403,
default = "kW/t",
link = "Power-to-weight ratio",
},
["hp/t"] = {
name1 = "horsepower per tonne",
name2 = "horsepower per tonne",
symbol = "hp/t",
utype = "power per unit mass",
scale = 0.74569987158227022,
default = "kW/t",
link = "Power-to-weight ratio",
},
["kW/kg"] = {
name1 = "kilowatt per kilogram",
name2 = "kilowatts per kilogram",
symbol = "kW/kg",
utype = "power per unit mass",
scale = 1000,
default = "hp/lb",
link = "Power-to-weight ratio",
},
["kW/t"] = {
name1 = "kilowatt per tonne",
name2 = "kilowatts per tonne",
symbol = "kW/t",
utype = "power per unit mass",
scale = 1,
default = "PS/t",
link = "Power-to-weight ratio",
},
["PS/t"] = {
name1 = "metric horsepower per tonne",
name2 = "metric horsepower per tonne",
symbol = "PS/t",
utype = "power per unit mass",
scale = 0.73549875,
default = "kW/t",
link = "Power-to-weight ratio",
},
["shp/lb"] = {
name1 = "shaft horsepower per pound",
name2 = "shaft horsepower per pound",
symbol = "shp/lb",
utype = "power per unit mass",
scale = 1643.986806,
default = "kW/kg",
link = "Power-to-weight ratio",
},
["hp/tonne"] = {
target = "hp/t",
symbol = "hp/tonne",
default = "kW/tonne",
},
["kW/tonne"] = {
target = "kW/t",
symbol = "kW/tonne",
},
["-lb/in2"] = {
name1 = "pound per square inch",
name2 = "pounds per square inch",
symbol = "lb/in<sup>2</sup>",
utype = "pressure",
scale = 6894.7572931683608,
default = "kPa kgf/cm2",
},
["atm"] = {
name1 = "standard atmosphere",
symbol = "atm",
utype = "pressure",
scale = 101325,
default = "kPa",
link = "Atmosphere (unit)",
},
["Ba"] = {
name1 = "barye",
symbol = "Ba",
utype = "pressure",
scale = 0.1,
default = "Pa",
},
["bar"] = {
symbol = "bar",
utype = "pressure",
scale = 100000,
default = "kPa",
link = "Bar (unit)",
},
["dbar"] = {
name1 = "decibar",
symbol = "dbar",
utype = "pressure",
scale = 10000,
default = "kPa",
link = "Bar (unit)",
},
["inHg"] = {
name1 = "inch of mercury",
name2 = "inches of mercury",
symbol = "inHg",
utype = "pressure",
scale = 3386.388640341,
default = "kPa",
},
["kBa"] = {
name1 = "kilobarye",
symbol = "kBa",
utype = "pressure",
scale = 100,
default = "hPa",
link = "Barye",
},
["kg-f/cm2"] = {
name1 = "kilogram-force per square centimetre",
name1_us = "kilogram-force per square centimeter",
name2 = "kilograms-force per square centimetre",
name2_us = "kilograms-force per square centimeter",
symbol = "kg<sub>f</sub>/cm<sup>2</sup>",
utype = "pressure",
scale = 98066.5,
default = "psi",
link = "Kilogram-force",
},
["kg/cm2"] = {
name1 = "kilogram per square centimetre",
name1_us = "kilogram per square centimeter",
name2 = "kilograms per square centimetre",
name2_us = "kilograms per square centimeter",
symbol = "kg/cm<sup>2</sup>",
utype = "pressure",
scale = 98066.5,
default = "psi",
link = "Kilogram-force",
},
["kgf/cm2"] = {
name1 = "kilogram-force per square centimetre",
name1_us = "kilogram-force per square centimeter",
name2 = "kilograms-force per square centimetre",
name2_us = "kilograms-force per square centimeter",
symbol = "kgf/cm<sup>2</sup>",
utype = "pressure",
scale = 98066.5,
default = "psi",
link = "Kilogram-force",
},
["ksi"] = {
name1 = "kilopound per square inch",
name2 = "kilopounds per square inch",
symbol = "ksi",
utype = "pressure",
scale = 6894757.2931683613,
default = "MPa",
link = "Pound per square inch",
},
["lbf/in2"] = {
name1 = "pound-force per square inch",
name2 = "pounds-force per square inch",
symbol = "lbf/in<sup>2</sup>",
utype = "pressure",
scale = 6894.7572931683608,
default = "kPa kgf/cm2",
},
["mb"] = {
name1 = "millibar",
symbol = "mb",
utype = "pressure",
scale = 100,
default = "hPa",
link = "Bar (unit)",
},
["mbar"] = {
name1 = "millibar",
symbol = "mbar",
utype = "pressure",
scale = 100,
default = "hPa",
link = "Bar (unit)",
},
["mmHg"] = {
name1 = "millimetre of mercury",
name1_us = "millimeter of mercury",
name2 = "millimetres of mercury",
name2_us = "millimeters of mercury",
symbol = "mmHg",
utype = "pressure",
scale = 133.322387415,
default = "kPa",
},
["Pa"] = {
_name1 = "pascal",
_symbol = "Pa",
utype = "pressure",
scale = 1,
prefixes = 1,
default = "psi",
link = "Pascal (unit)",
},
["psf"] = {
name1 = "pound per square foot",
name2 = "pounds per square foot",
symbol = "psf",
utype = "pressure",
scale = 47.880258980335839,
default = "kPa",
link = "Pound per square inch",
},
["psi"] = {
name1 = "pound per square inch",
name2 = "pounds per square inch",
symbol = "psi",
utype = "pressure",
scale = 6894.7572931683608,
default = "kPa",
},
["Torr"] = {
name1 = "torr",
symbol = "Torr",
utype = "pressure",
scale = 133.32236842105263,
default = "kPa",
},
["N/cm2"] = {
per = { "N", "cm2" },
utype = "pressure",
default = "psi",
},
["N/m2"] = {
per = { "N", "m2" },
utype = "pressure",
default = "psi",
},
["g/cm2"] = {
per = { "g", "cm2" },
utype = "pressure",
default = "lb/sqft",
multiplier= 9.80665,
},
["g/m2"] = {
per = { "g", "m2" },
utype = "pressure",
default = "lb/sqft",
multiplier= 9.80665,
},
["kg/ha"] = {
per = { "kg", "ha" },
utype = "pressure",
default = "lb/acre",
multiplier= 9.80665,
},
["kg/m2"] = {
per = { "kg", "m2" },
utype = "pressure",
default = "lb/sqft",
multiplier= 9.80665,
},
["lb/1000sqft"] = {
per = { "lb", "1000sqft" },
utype = "pressure",
default = "g/m2",
multiplier= 9.80665,
},
["lb/acre"] = {
per = { "lb", "acre" },
utype = "pressure",
default = "kg/ha",
multiplier= 9.80665,
},
["lb/sqft"] = {
per = { "lb", "sqft" },
utype = "pressure",
default = "kg/m2",
multiplier= 9.80665,
},
["lb/sqyd"] = {
per = { "lb", "sqyd" },
utype = "pressure",
default = "kg/m2",
multiplier= 9.80665,
},
["LT/acre"] = {
per = { "LT", "acre" },
utype = "pressure",
default = "t/ha",
multiplier= 9.80665,
},
["MT/ha"] = {
per = { "MT", "ha" },
utype = "pressure",
default = "LT/acre ST/acre",
multiplier= 9.80665,
},
["oz/sqft"] = {
per = { "oz", "sqft" },
utype = "pressure",
default = "g/m2",
multiplier= 9.80665,
},
["oz/sqyd"] = {
per = { "oz", "sqyd" },
utype = "pressure",
default = "g/m2",
multiplier= 9.80665,
},
["ST/acre"] = {
per = { "ST", "acre" },
utype = "pressure",
default = "t/ha",
multiplier= 9.80665,
},
["t/ha"] = {
per = { "t", "ha" },
utype = "pressure",
default = "LT/acre ST/acre",
multiplier= 9.80665,
},
["tonne/acre"] = {
per = { "tonne", "acre" },
utype = "pressure",
default = "tonne/ha",
multiplier= 9.80665,
},
["tonne/ha"] = {
per = { "tonne", "ha" },
utype = "pressure",
default = "tonne/acre",
multiplier= 9.80665,
},
["kgfpsqcm"] = {
target = "kgf/cm2",
},
["kgpsqcm"] = {
target = "kg/cm2",
},
["kN/m2"] = {
target = "kPa",
},
["lb/in2"] = {
target = "lbf/in2",
},
["torr"] = {
target = "Torr",
},
["Bq"] = {
_name1 = "becquerel",
_symbol = "Bq",
utype = "radioactivity",
scale = 1,
prefixes = 1,
default = "pCi",
link = "Becquerel",
},
["Ci"] = {
_name1 = "curie",
_symbol = "Ci",
utype = "radioactivity",
scale = 3.7e10,
prefixes = 1,
default = "GBq",
link = "Curie (unit)",
},
["Rd"] = {
_name1 = "rutherford",
_symbol = "Rd",
utype = "radioactivity",
scale = 1e6,
prefixes = 1,
default = "MBq",
link = "Rutherford (unit)",
},
["cm/h"] = {
name1 = "centimetre per hour",
name1_us = "centimeter per hour",
name2 = "centimetres per hour",
name2_us = "centimeters per hour",
symbol = "cm/h",
utype = "speed",
scale = 2.7777777777777775e-6,
default = "in/h",
link = "Metre per second",
},
["cm/s"] = {
name1 = "centimetre per second",
name1_us = "centimeter per second",
name2 = "centimetres per second",
name2_us = "centimeters per second",
symbol = "cm/s",
utype = "speed",
scale = 0.01,
default = "in/s",
link = "Metre per second",
},
["cm/year"] = {
name1 = "centimetre per year",
name1_us = "centimeter per year",
name2 = "centimetres per year",
name2_us = "centimeters per year",
symbol = "cm/year",
utype = "speed",
scale = 3.168873850681143e-10,
default = "in/year",
link = "Orders of magnitude (speed)",
},
["foot/s"] = {
name1 = "foot per second",
name2 = "foot per second",
symbol = "ft/s",
utype = "speed",
scale = 0.3048,
default = "m/s",
},
["ft/min"] = {
name1 = "foot per minute",
name2 = "feet per minute",
symbol = "ft/min",
utype = "speed",
scale = 0.00508,
default = "m/min",
link = "Feet per second",
},
["ft/s"] = {
name1 = "foot per second",
name2 = "feet per second",
symbol = "ft/s",
utype = "speed",
scale = 0.3048,
default = "m/s",
link = "Feet per second",
},
["furlong per fortnight"] = {
name2 = "furlongs per fortnight",
symbol = "furlong per fortnight",
usename = 1,
utype = "speed",
scale = 0.00016630952380952381,
default = "km/h mph",
link = "FFF system",
},
["in/h"] = {
name1 = "inch per hour",
name2 = "inches per hour",
symbol = "in/h",
utype = "speed",
scale = 7.0555555555555559e-6,
default = "cm/h",
link = "Inch",
},
["in/s"] = {
name1 = "inch per second",
name2 = "inches per second",
symbol = "in/s",
utype = "speed",
scale = 0.0254,
default = "cm/s",
link = "Inch",
},
["in/year"] = {
name1 = "inch per year",
name2 = "inches per year",
symbol = "in/year",
utype = "speed",
scale = 8.0489395807301024e-10,
default = "cm/year",
link = "Orders of magnitude (speed)",
},
["isp"] = {
name1 = "second",
symbol = "s",
utype = "speed",
scale = 9.80665,
default = "km/s",
link = "Specific impulse",
},
["km/d"] = {
name1 = "kilometre per day",
name1_us = "kilometer per day",
name2 = "kilometres per day",
name2_us = "kilometers per day",
symbol = "km/d",
utype = "speed",
scale = 1.1574074074074074e-2,
default = "mi/d",
link = "Orders of magnitude (speed)",
},
["km/h"] = {
name1 = "kilometre per hour",
name1_us = "kilometer per hour",
name2 = "kilometres per hour",
name2_us = "kilometers per hour",
symbol = "km/h",
utype = "speed",
scale = 0.27777777777777779,
default = "mph",
link = "Kilometres per hour",
},
["km/s"] = {
name1 = "kilometre per second",
name1_us = "kilometer per second",
name2 = "kilometres per second",
name2_us = "kilometers per second",
symbol = "km/s",
utype = "speed",
scale = 1000,
default = "mi/s",
link = "Metre per second",
},
["kn"] = {
name1 = "knot",
symbol = "kn",
utype = "speed",
scale = 0.51444444444444448,
default = "km/h mph",
link = "Knot (unit)",
},
["kNs/kg"] = {
name2 = "kN‑s/kg",
symbol = "kN‑s/kg",
utype = "speed",
scale = 1000,
default = "isp",
link = "Specific impulse",
},
["m/min"] = {
name1 = "metre per minute",
name1_us = "meter per minute",
name2 = "metres per minute",
name2_us = "meters per minute",
symbol = "m/min",
utype = "speed",
scale = 0.016666666666666666,
default = "ft/min",
link = "Metre per second",
},
["m/s"] = {
name1 = "metre per second",
name1_us = "meter per second",
name2 = "metres per second",
name2_us = "meters per second",
symbol = "m/s",
utype = "speed",
scale = 1,
default = "ft/s",
},
["Mach"] = {
name2 = "Mach",
symbol = "Mach",
utype = "speed",
builtin = "mach",
scale = 0,
iscomplex= true,
default = "km/h mph",
link = "Mach number",
},
["mi/d"] = {
name1 = "mile per day",
name2 = "miles per day",
symbol = "mi/d",
utype = "speed",
scale = 1.8626666666666667e-2,
default = "km/d",
link = "Orders of magnitude (speed)",
},
["mi/s"] = {
name1 = "mile per second",
name2 = "miles per second",
symbol = "mi/s",
utype = "speed",
scale = 1609.344,
default = "km/s",
link = "Mile",
},
["mm/h"] = {
name1 = "millimetre per hour",
name1_us = "millimeter per hour",
name2 = "millimetres per hour",
name2_us = "millimeters per hour",
symbol = "mm/h",
utype = "speed",
scale = 2.7777777777777781e-7,
default = "in/h",
link = "Metre per second",
},
["mph"] = {
name1 = "mile per hour",
name2 = "miles per hour",
symbol = "mph",
utype = "speed",
scale = 0.44704,
default = "km/h",
link = "Miles per hour",
},
["Ns/kg"] = {
name2 = "N‑s/kg",
symbol = "N‑s/kg",
utype = "speed",
scale = 1,
default = "isp",
link = "Specific impulse",
},
["si tsfc"] = {
name2 = "g/(kN⋅s)",
symbol = "g/(kN⋅s)",
utype = "speed",
scale = 9.9999628621379242e-7,
invert = -1,
iscomplex= true,
default = "tsfc",
link = "Thrust specific fuel consumption",
},
["tsfc"] = {
name2 = "lb/(lbf⋅h)",
symbol = "lb/(lbf⋅h)",
utype = "speed",
scale = 2.832545036049801e-5,
invert = -1,
iscomplex= true,
default = "si tsfc",
link = "Thrust specific fuel consumption",
},
["cm/y"] = {
target = "cm/year",
},
["cm/yr"] = {
target = "cm/year",
},
["in/y"] = {
target = "in/year",
},
["in/yr"] = {
target = "in/year",
},
["knot"] = {
target = "kn",
},
["knots"] = {
target = "kn",
},
["kph"] = {
target = "km/h",
},
["mi/h"] = {
target = "mph",
},
["mm/s"] = {
per = { "mm", "s" },
utype = "speed",
default = "in/s",
link = "Metre per second",
},
["C"] = {
name1 = "degree Celsius",
name2 = "degrees Celsius",
symbol = "°C",
usesymbol= 1,
utype = "temperature",
scale = 1,
offset = -273.15,
iscomplex= true,
istemperature= true,
default = "F",
link = "Celsius",
},
["F"] = {
name1 = "degree Fahrenheit",
name2 = "degrees Fahrenheit",
symbol = "°F",
usesymbol= 1,
utype = "temperature",
scale = 0.55555555555555558,
offset = 32-273.15*(9/5),
iscomplex= true,
istemperature= true,
default = "C",
link = "Fahrenheit",
},
["K"] = {
_name1 = "kelvin",
_symbol = "K",
usesymbol= 1,
utype = "temperature",
scale = 1,
offset = 0,
iscomplex= true,
istemperature= true,
prefixes = 1,
default = "C F",
link = "Kelvin",
},
["keVT"] = {
name1 = "kiloelectronvolt",
symbol = "keV",
utype = "temperature",
scale = 11.604505e6,
offset = 0,
iscomplex= true,
default = "MK",
link = "Electronvolt",
},
["R"] = {
name1 = "degree Rankine",
name2 = "degrees Rankine",
symbol = "°R",
usesymbol= 1,
utype = "temperature",
scale = 0.55555555555555558,
offset = 0,
iscomplex= true,
istemperature= true,
default = "K F C",
link = "Rankine scale",
},
["Celsius"] = {
target = "C",
},
["°C"] = {
target = "C",
},
["°F"] = {
target = "F",
},
["°R"] = {
target = "R",
},
["C-change"] = {
name1 = "degree Celsius change",
name2 = "degrees Celsius change",
symbol = "°C",
usesymbol= 1,
utype = "temperature change",
scale = 1,
default = "F-change",
link = "Celsius",
},
["F-change"] = {
name1 = "degree Fahrenheit change",
name2 = "degrees Fahrenheit change",
symbol = "°F",
usesymbol= 1,
utype = "temperature change",
scale = 0.55555555555555558,
default = "C-change",
link = "Fahrenheit",
},
["K-change"] = {
name1 = "kelvin change",
name2 = "kelvins change",
symbol = "K",
usesymbol= 1,
utype = "temperature change",
scale = 1,
default = "F-change",
link = "Kelvin",
},
["°C-change"] = {
target = "C-change",
},
["°F-change"] = {
target = "F-change",
},
["century"] = {
name1 = "century",
name2 = "centuries",
symbol = "ha",
utype = "time",
scale = 3155760000,
default = "Gs",
},
["d"] = {
name1 = "day",
symbol = "d",
utype = "time",
scale = 86400,
default = "ks",
},
["decade"] = {
name1 = "decade",
symbol = "daa",
utype = "time",
scale = 315576000,
default = "Ms",
},
["dog year"] = {
name1 = "dog year",
symbol = "dog yr",
utype = "time",
scale = 220903200,
default = "years",
link = "List of unusual units of measurement#Dog year",
},
["fortnight"] = {
symbol = "fortnight",
usename = 1,
utype = "time",
scale = 1209600,
default = "week",
},
["h"] = {
name1 = "hour",
symbol = "h",
utype = "time",
scale = 3600,
default = "ks",
},
["long billion year"] = {
name1 = "billion years",
name2 = "billion years",
symbol = "Ta",
utype = "time",
scale = 31557600000000000000,
default = "Es",
link = "Annum",
},
["millennium"] = {
name1 = "millennium",
name2 = "millennia",
symbol = "ka",
utype = "time",
scale = 31557600000,
default = "Gs",
},
["milliard year"] = {
name1 = "milliard years",
name2 = "milliard years",
symbol = "Ga",
utype = "time",
scale = 31557600000000000,
default = "Ps",
link = "Annum",
},
["million year"] = {
name1 = "million years",
name2 = "million years",
symbol = "Ma",
utype = "time",
scale = 31557600000000,
default = "Ts",
link = "Annum",
},
["min"] = {
name1 = "minute",
symbol = "min",
utype = "time",
scale = 60,
default = "s",
},
["month"] = {
symbol = "month",
usename = 1,
utype = "time",
scale = 2629800,
default = "Ms",
},
["months"] = {
name1 = "month",
symbol = "mo",
utype = "time",
scale = 2629800,
default = "year",
},
["s"] = {
_name1 = "second",
_symbol = "s",
utype = "time",
scale = 1,
prefixes = 1,
default = "v < 7200 ! min ! h",
link = "Second",
},
["short billion year"] = {
name1 = "billion years",
name2 = "billion years",
symbol = "Ga",
utype = "time",
scale = 31557600000000000,
default = "Ps",
link = "Annum",
},
["short trillion year"] = {
name1 = "trillion years",
name2 = "trillion years",
symbol = "Ta",
utype = "time",
scale = 31557600000000000000,
default = "Es",
link = "Annum",
},
["thousand million year"] = {
name1 = "thousand million years",
name2 = "thousand million years",
symbol = "Ga",
utype = "time",
scale = 31557600000000000,
default = "Ps",
link = "Annum",
},
["wk"] = {
symbol = "week",
usename = 1,
utype = "time",
scale = 604800,
default = "Ms",
},
["year"] = {
name1 = "year",
symbol = "a",
utype = "time",
scale = 31557600,
default = "Ms",
link = "Annum",
},
["years"] = {
name1 = "year",
symbol = "yr",
utype = "time",
scale = 31557600,
default = "Ms",
link = "Annum",
},
["byr"] = {
target = "short billion year",
},
["day"] = {
target = "d",
},
["days"] = {
target = "d",
},
["dog yr"] = {
target = "dog year",
},
["Gyr"] = {
target = "thousand million year",
},
["hour"] = {
target = "h",
},
["hours"] = {
target = "h",
},
["kMyr"] = {
target = "thousand million year",
},
["kmyr"] = {
target = "thousand million year",
},
["kyr"] = {
target = "millennium",
},
["long byr"] = {
target = "long billion year",
},
["minute"] = {
target = "min",
},
["minutes"] = {
target = "min",
},
["mth"] = {
target = "month",
},
["Myr"] = {
target = "million year",
},
["myr"] = {
target = "million year",
},
["sec"] = {
target = "s",
},
["second"] = {
target = "s",
},
["seconds"] = {
target = "s",
},
["tmyr"] = {
target = "thousand million year",
},
["tryr"] = {
target = "short trillion year",
},
["tyr"] = {
target = "millennium",
},
["week"] = {
target = "wk",
},
["weeks"] = {
target = "wk",
},
["yr"] = {
target = "year",
},
["kg.m"] = {
name1 = "kilogram metre",
name1_us = "kilogram meter",
symbol = "kg⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbft",
link = "Kilogram metre (torque)",
},
["kgf.m"] = {
name1 = "kilogram force-metre",
name1_us = "kilogram force-meter",
symbol = "kgf⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["kgm"] = {
name1 = "kilogram metre",
name1_us = "kilogram meter",
symbol = "kg⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["kpm"] = {
name1 = "kilopond metre",
name1_us = "kilopond meter",
symbol = "kp⋅m",
utype = "torque",
scale = 9.80665,
default = "Nm lbft",
link = "Kilogram metre (torque)",
},
["lb-fft"] = {
name1 = "pound force-foot",
name2 = "pound force-feet",
symbol = "ft⋅lb<sub>f</sub>",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["lb.ft"] = {
name1 = "pound force-foot",
name2 = "pound force-feet",
symbol = "lb⋅ft",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["lb.in"] = {
name1 = "pound force-inch",
symbol = "lb⋅in",
utype = "torque",
scale = 0.1129848290276167,
default = "mN.m",
link = "Pound-foot (torque)",
},
["lbfft"] = {
name1 = "pound force-foot",
name2 = "pound force-feet",
symbol = "lbf⋅ft",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["lbft"] = {
name1 = "pound-foot",
name2 = "pound-feet",
symbol = "lb⋅ft",
utype = "torque",
scale = 1.3558179483314004,
default = "Nm",
link = "Pound-foot (torque)",
},
["m.kg-f"] = {
name1 = "metre kilogram-force",
name1_us = "meter kilogram-force",
name2 = "metre kilograms-force",
name2_us = "meter kilograms-force",
symbol = "m⋅kg<sub>f</sub>",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["m.kgf"] = {
name1 = "metre kilogram-force",
name1_us = "meter kilogram-force",
name2 = "metre kilograms-force",
name2_us = "meter kilograms-force",
symbol = "m⋅kgf",
utype = "torque",
scale = 9.80665,
default = "Nm lbfft",
link = "Kilogram metre (torque)",
},
["mN.m"] = {
name1 = "millinewton-metre",
name1_us = "millinewton-meter",
symbol = "mN⋅m",
utype = "torque",
scale = 0.001,
default = "lb.in",
link = "Newton-metre",
},
["Nm"] = {
_name1 = "newton-metre",
_name1_us= "newton-meter",
_symbol = "N⋅m",
utype = "torque",
alttype = "energy",
scale = 1,
prefixes = 1,
default = "lbfft",
link = "Newton-metre",
},
["kN/m"] = {
per = { "kN", "-m-stiff" },
utype = "torque",
default = "lbf/in",
},
["lbf/in"] = {
per = { "lbf", "-in-stiff" },
utype = "torque",
default = "kN/m",
},
["lb-f.ft"] = {
target = "lb-fft",
},
["lbf.ft"] = {
target = "lbfft",
},
["lbf·ft"] = {
target = "lbfft",
},
["lb·ft"] = {
target = "lb.ft",
},
["mkg-f"] = {
target = "m.kg-f",
},
["mkgf"] = {
target = "m.kgf",
},
["N.m"] = {
target = "Nm",
},
["N·m"] = {
target = "Nm",
},
["ton-mile"] = {
symbol = "ton-mile",
usename = 1,
utype = "transportation",
scale = 1.4599723182105602,
default = "tkm",
},
["tkm"] = {
name1 = "tonne-kilometre",
name1_us = "tonne-kilometer",
symbol = "tkm",
utype = "transportation",
scale = 1,
default = "ton-mile",
},
["-12USoz(mL)serve"] = {
name1_us = "12 U.S. fl oz (355 mL) serving",
symbol = "12 US fl oz (355 mL) serving",
sym_us = "12 U.S. fl oz (355 mL) serving",
utype = "volume",
scale = 0.00035488235475000004,
default = "mL",
link = "Beverage can#Standard sizes",
},
["-12USoz(ml)serve"] = {
name1_us = "12 U.S. fl oz (355 ml) serving",
symbol = "12 US fl oz (355 ml) serving",
sym_us = "12 U.S. fl oz (355 ml) serving",
utype = "volume",
scale = 0.00035488235475000004,
default = "ml",
link = "Beverage can#Standard sizes",
},
["-12USozserve"] = {
name1_us = "12 U.S. fl oz serving",
symbol = "12 US fl oz serving",
sym_us = "12 U.S. fl oz serving",
utype = "volume",
scale = 0.00035488235475000004,
default = "mL",
link = "Beverage can#Standard sizes",
},
["acre-foot"] = {
name1 = "acre-foot",
name2 = "acre-foot",
symbol = "acre⋅ft",
utype = "volume",
scale = 1233.48183754752,
default = "m3",
},
["acre-ft"] = {
name1 = "acre-foot",
name2 = "acre-feet",
symbol = "acre⋅ft",
utype = "volume",
scale = 1233.48183754752,
default = "m3",
},
["AUtbsp"] = {
name1 = "Australian tablespoon",
symbol = "AU tbsp",
utype = "volume",
scale = 0.000020,
default = "ml",
},
["Bcuft"] = {
name1 = "billion cubic foot",
name2 = "billion cubic feet",
symbol = "billion cu ft",
utype = "volume",
scale = 28316846.592,
default = "Gl",
link = "Cubic foot",
},
["bdft"] = {
name1 = "board foot",
name2 = "board feet",
symbol = "bd ft",
utype = "volume",
scale = 0.0023597372167,
default = "m3",
},
["board feet"] = {
name2 = "board feet",
symbol = "board foot",
usename = 1,
utype = "volume",
scale = 0.0023597372167,
default = "m3",
},
["board foot"] = {
name2 = "board foot",
symbol = "board foot",
usename = 1,
utype = "volume",
scale = 0.0023597372167,
default = "m3",
},
["cc"] = {
name1 = "cubic centimetre",
name1_us = "cubic centimeter",
symbol = "cc",
utype = "volume",
scale = 0.000001,
default = "cuin",
},
["CID"] = {
name1 = "cubic inch",
name2 = "cubic inches",
symbol = "cu in",
utype = "volume",
scale = 0.000016387064,
default = "cc",
link = "Cubic inch#Engine displacement",
},
["cord"] = {
symbol = "cord",
utype = "volume",
scale = 3.624556363776,
default = "m3",
link = "Cord (unit)",
},
["cufoot"] = {
name1 = "cubic foot",
name2 = "cubic foot",
symbol = "cu ft",
utype = "volume",
scale = 0.028316846592,
default = "m3",
},
["cuft"] = {
name1 = "cubic foot",
name2 = "cubic feet",
symbol = "cu ft",
utype = "volume",
scale = 0.028316846592,
default = "m3",
},
["cuin"] = {
name1 = "cubic inch",
name2 = "cubic inches",
symbol = "cu in",
utype = "volume",
scale = 0.000016387064,
default = "cm3",
},
["cumi"] = {
name1 = "cubic mile",
symbol = "cu mi",
utype = "volume",
scale = 4168181825.440579584,
default = "km3",
},
["cuyd"] = {
name1 = "cubic yard",
symbol = "cu yd",
utype = "volume",
scale = 0.764554857984,
default = "m3",
},
["firkin"] = {
symbol = "firkin",
usename = 1,
utype = "volume",
scale = 0.04091481,
default = "L impgal USgal",
link = "Firkin (unit)",
},
["foot3"] = {
target = "cufoot",
},
["Goilbbl"] = {
name1 = "billion barrels",
name2 = "billion barrels",
symbol = "Gbbl",
utype = "volume",
scale = 158987294.928,
default = "v * 1.58987294928 < 10 ! e6 ! e9 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["gr water"] = {
name1 = "grains water",
name2 = "grains water",
symbol = "gr H<sub>2</sub>O",
utype = "volume",
scale = 0.00000006479891,
default = "cm3",
link = "Grain (unit)",
},
["grt"] = {
name1 = "gross register ton",
symbol = "grt",
utype = "volume",
scale = 2.8316846592,
default = "m3",
link = "Gross register tonnage",
},
["impbbl"] = {
name1 = "imperial barrel",
symbol = "imp bbl",
utype = "volume",
scale = 0.16365924,
default = "L impgal USgal",
link = "Barrel (unit)",
},
["impbsh"] = {
name1 = "imperial bushel",
symbol = "imp bsh",
utype = "volume",
scale = 0.03636872,
default = "L impgal USdrygal",
},
["impbu"] = {
name1 = "imperial bushel",
symbol = "imp bu",
utype = "volume",
scale = 0.03636872,
default = "m3",
},
["impgal"] = {
name1 = "imperial gallon",
symbol = "imp gal",
utype = "volume",
scale = 0.00454609,
default = "L USgal",
},
["impgi"] = {
name1 = "gill",
symbol = "gi",
utype = "volume",
scale = 0.0001420653125,
default = "ml USoz",
link = "Gill (unit)",
},
["impkenning"] = {
name1 = "imperial kenning",
symbol = "kenning",
utype = "volume",
scale = 0.01818436,
default = "L USdrygal",
link = "Kenning (unit)",
},
["impoz"] = {
name1 = "imperial fluid ounce",
symbol = "imp fl oz",
utype = "volume",
scale = 0.0000284130625,
default = "ml USoz",
},
["imppk"] = {
name1 = "imperial peck",
symbol = "pk",
utype = "volume",
scale = 0.00909218,
default = "L USdrygal",
link = "Peck",
},
["imppt"] = {
name1 = "imperial pint",
symbol = "imp pt",
utype = "volume",
scale = 0.00056826125,
default = "L",
},
["impqt"] = {
name1 = "imperial quart",
symbol = "imp qt",
utype = "volume",
scale = 0.0011365225,
default = "ml USoz",
customary= 3,
},
["kilderkin"] = {
symbol = "kilderkin",
usename = 1,
utype = "volume",
scale = 0.08182962,
default = "L impgal USgal",
},
["koilbbl"] = {
name1 = "thousand barrels",
name2 = "thousand barrels",
symbol = "kbbl",
utype = "volume",
scale = 158.987294928,
default = "v * 1.58987294928 < 10 ! ! e3 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["L"] = {
_name1 = "litre",
_name1_us= "liter",
_symbol = "L",
utype = "volume",
scale = 0.001,
prefixes = 1,
default = "impgal USgal",
link = "Litre",
},
["l"] = {
_name1 = "litre",
_name1_us= "liter",
_symbol = "l",
utype = "volume",
scale = 0.001,
prefixes = 1,
default = "impgal USgal",
link = "Litre",
},
["ll"] = {
name1 = "litre",
name1_us = "liter",
symbol = "l",
utype = "volume",
scale = 0.001,
default = "impgal USgal",
},
["m3"] = {
_name1 = "cubic metre",
_name1_us= "cubic meter",
_symbol = "m<sup>3</sup>",
prefix_position= 7,
utype = "volume",
scale = 1,
prefixes = 3,
default = "cuft",
link = "Cubic metre",
},
["Mbbl"] = {
name1 = "thousand barrels",
name2 = "thousand barrels",
symbol = "Mbbl",
utype = "volume",
scale = 158.987294928,
default = "v * 1.58987294928 < 10 ! e3 ! ! m3",
link = "Barrel (unit)#Oil barrel",
},
["MMoilbbl"] = {
name1 = "million barrels",
name2 = "million barrels",
symbol = "MMbbl",
utype = "volume",
scale = 158987.294928,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["Moilbbl"] = {
name1 = "million barrels",
name2 = "million barrels",
symbol = "Mbbl",
utype = "volume",
scale = 158987.294928,
default = "v * 1.58987294928 < 10 ! e3 ! e6 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["MTON"] = {
name1 = "measurement ton",
symbol = "MTON",
utype = "volume",
scale = 1.13267386368,
default = "m3",
},
["MUSgal"] = {
name1 = "million US gallons",
name1_us = "million U.S. gallons",
name2 = "million US gallons",
name2_us = "million U.S. gallons",
symbol = "million US gal",
sym_us = "million U.S. gal",
utype = "volume",
scale = 3785.411784,
default = "Ml",
link = "US gallon",
},
["oilbbl"] = {
name1 = "barrel",
symbol = "bbl",
utype = "volume",
scale = 0.158987294928,
default = "m3",
link = "Barrel (unit)#Oil barrel",
},
["stere"] = {
symbol = "stere",
usename = 1,
utype = "volume",
scale = 1,
default = "cuft",
},
["Toilbbl"] = {
name1 = "trillion barrels",
name2 = "trillion barrels",
symbol = "Tbbl",
utype = "volume",
scale = 158987294928,
default = "v * 1.58987294928 < 10 ! e9 ! e12 ! m3",
link = "Barrel (unit)#Oil barrel",
},
["USbbl"] = {
name1 = "US barrel",
name1_us = "U.S. barrel",
symbol = "US bbl",
sym_us = "U.S. bbl",
utype = "volume",
scale = 0.119240471196,
default = "L USgal impgal",
link = "Barrel (unit)",
},
["USbeerbbl"] = {
name1 = "US beer barrel",
name1_us = "U.S. beer barrel",
symbol = "US bbl",
sym_us = "U.S. bbl",
utype = "volume",
scale = 0.117347765304,
default = "L USgal impgal",
link = "Barrel (unit)",
},
["USbsh"] = {
name1 = "US bushel",
name1_us = "U.S. bushel",
symbol = "US bsh",
sym_us = "U.S. bsh",
utype = "volume",
scale = 0.03523907016688,
default = "L USdrygal impgal",
link = "Bushel",
},
["USbu"] = {
name1 = "US bushel",
name1_us = "U.S. bushel",
symbol = "US bu",
sym_us = "U.S. bu",
utype = "volume",
scale = 0.03523907016688,
default = "L USdrygal impgal",
link = "Bushel",
},
["USdrybbl"] = {
name1 = "US dry barrel",
name1_us = "U.S. dry barrel",
symbol = "US dry bbl",
sym_us = "U.S. dry bbl",
utype = "volume",
scale = 0.11562819898508,
default = "m3",
link = "Barrel (unit)",
},
["USdrygal"] = {
name1 = "US dry gallon",
name1_us = "U.S. dry gallon",
symbol = "US dry gal",
sym_us = "U.S. dry gal",
utype = "volume",
scale = 0.00440488377086,
default = "L",
link = "Gallon",
},
["USdrypt"] = {
name1 = "US dry pint",
name1_us = "U.S. dry pint",
symbol = "US dry pt",
sym_us = "U.S. dry pt",
utype = "volume",
scale = 0.0005506104713575,
default = "ml",
link = "Pint",
},
["USdryqt"] = {
name1 = "US dry quart",
name1_us = "U.S. dry quart",
symbol = "US dry qt",
sym_us = "U.S. dry qt",
utype = "volume",
scale = 0.001101220942715,
default = "ml",
link = "Quart",
},
["USflgal"] = {
name1 = "US gallon",
name1_us = "U.S. gallon",
symbol = "US fl gal",
sym_us = "U.S. fl gal",
utype = "volume",
scale = 0.003785411784,
default = "L impgal",
link = "Gallon",
},
["USgal"] = {
name1 = "US gallon",
name1_us = "U.S. gallon",
symbol = "US gal",
sym_us = "U.S. gal",
utype = "volume",
scale = 0.003785411784,
default = "L impgal",
},
["USgi"] = {
name1 = "gill",
symbol = "gi",
utype = "volume",
scale = 0.0001182941183,
default = "ml impoz",
link = "Gill (unit)",
},
["USkenning"] = {
name1 = "US kenning",
name1_us = "U.S. kenning",
symbol = "US kenning",
sym_us = "U.S. kenning",
utype = "volume",
scale = 0.01761953508344,
default = "L impgal",
link = "Kenning (unit)",
},
["USmin"] = {
name1 = "US minim",
name1_us = "U.S. minim",
symbol = "US min",
sym_us = "U.S. min",
utype = "volume",
scale = 0.000000061611519921875,
default = "ml",
link = "Minim (unit)",
},
["USoz"] = {
name1 = "US fluid ounce",
name1_us = "U.S. fluid ounce",
symbol = "US fl oz",
sym_us = "U.S. fl oz",
utype = "volume",
scale = 0.0000295735295625,
default = "ml",
},
["USpk"] = {
name1 = "US peck",
name1_us = "U.S. peck",
symbol = "US pk",
sym_us = "U.S. pk",
utype = "volume",
scale = 0.00880976754172,
default = "L impgal",
link = "Peck",
},
["USpt"] = {
name1 = "US pint",
name1_us = "U.S. pint",
symbol = "US pt",
sym_us = "U.S. pt",
utype = "volume",
scale = 0.000473176473,
default = "L imppt",
link = "Pint",
},
["USqt"] = {
name1 = "US quart",
name1_us = "U.S. quart",
symbol = "US qt",
sym_us = "U.S. qt",
utype = "volume",
scale = 0.000946352946,
default = "ml",
link = "Quart",
customary= 1,
},
["USquart"] = {
name1 = "US quart",
name1_us = "U.S. quart",
symbol = "US qt",
sym_us = "U.S. qt",
utype = "volume",
scale = 0.000946352946,
default = "ml impoz",
link = "Quart",
},
["UStbsp"] = {
name1 = "US tablespoon",
name1_us = "U.S. tablespoon",
symbol = "US tbsp",
sym_us = "U.S. tbsp",
utype = "volume",
scale = 1.4786764781250001e-5,
default = "ml",
},
["winecase"] = {
symbol = "case",
usename = 1,
utype = "volume",
scale = 0.009,
default = "L",
link = "Case (goods)",
},
["*U.S.drygal"] = {
target = "USdrygal",
sp_us = true,
customary= 2,
},
["*U.S.gal"] = {
target = "USgal",
sp_us = true,
customary= 2,
},
["+USdrygal"] = {
target = "USdrygal",
customary= 1,
},
["+usfloz"] = {
target = "USoz",
link = "Fluid ounce",
customary= 1,
},
["+USgal"] = {
target = "USgal",
customary= 1,
},
["+USoz"] = {
target = "USoz",
customary= 1,
},
["@impgal"] = {
target = "impgal",
link = "Gallon",
customary= 3,
},
["acre feet"] = {
target = "acre-ft",
},
["acre foot"] = {
target = "acre-foot",
},
["acre ft"] = {
target = "acre-ft",
},
["acre-feet"] = {
target = "acre-ft",
},
["acre.foot"] = {
target = "acre-foot",
},
["acre.ft"] = {
target = "acre-ft",
},
["acre·ft"] = {
target = "acre-ft",
},
["bushels"] = {
target = "USbsh",
},
["cid"] = {
target = "CID",
},
["ft3"] = {
target = "cuft",
},
["gal"] = {
target = "USgal",
},
["gallon"] = {
shouldbe = "Use %{USgal%} for US gallons or %{impgal%} for imperial gallons (not %{gallon%})",
},
["gallons"] = {
shouldbe = "Use %{USgal%} for US gallons or %{impgal%} for imperial gallons (not %{gallons%})",
},
["Gcuft"] = {
target = "e9cuft",
},
["impfloz"] = {
target = "impoz",
},
["Impgal"] = {
target = "impgal",
},
["in3"] = {
target = "cuin",
symbol = "in<sup>3</sup>",
},
["hm³"] = {
target = "hm3",
},
["kcuft"] = {
target = "e3cuft",
},
["kcum"] = {
target = "e3m3",
},
["km³"] = {
target = "km3",
},
["liter"] = {
target = "L",
sp_us = true,
},
["liters"] = {
target = "L",
sp_us = true,
},
["litre"] = {
target = "L",
},
["litres"] = {
target = "L",
},
["Mcuft"] = {
target = "e6cuft",
},
["Mcum"] = {
target = "e6m3",
},
["Mft3"] = {
target = "e6cuft",
},
["mi3"] = {
target = "cumi",
},
["m³"] = {
target = "m3",
},
["Pcuft"] = {
target = "e15cuft",
},
["pt"] = {
shouldbe = "Use %{USpt%} for US pints or %{imppt%} for imperial pints (not %{pt%})",
},
["qt"] = {
shouldbe = "Use %{USqt%} for US quarts or %{impqt%} for imperial quarts (not %{qt%})",
},
["Tcuft"] = {
target = "e12cuft",
},
["Tft3"] = {
target = "e12cuft",
},
["U.S.bbl"] = {
target = "USbbl",
sp_us = true,
default = "L U.S.gal impgal",
},
["U.S.beerbbl"] = {
target = "USbeerbbl",
sp_us = true,
default = "L U.S.gal impgal",
},
["U.S.bsh"] = {
target = "USbsh",
sp_us = true,
default = "L U.S.drygal impgal",
},
["U.S.bu"] = {
target = "USbu",
sp_us = true,
default = "L U.S.drygal impgal",
},
["U.S.drybbl"] = {
target = "USdrybbl",
sp_us = true,
},
["U.S.drygal"] = {
target = "USdrygal",
sp_us = true,
},
["U.S.drypt"] = {
target = "USdrypt",
sp_us = true,
},
["U.S.dryqt"] = {
target = "USdryqt",
sp_us = true,
},
["U.S.flgal"] = {
target = "USflgal",
sp_us = true,
},
["U.S.floz"] = {
target = "USoz",
sp_us = true,
},
["U.S.gal"] = {
target = "USgal",
sp_us = true,
link = "U.S. gallon",
},
["u.s.gal"] = {
target = "USgal",
sp_us = true,
link = "U.S. gallon",
},
["U.S.gi"] = {
target = "USgi",
sp_us = true,
},
["U.S.kenning"] = {
target = "USkenning",
sp_us = true,
},
["U.S.oz"] = {
target = "USoz",
sp_us = true,
},
["U.S.pk"] = {
target = "USpk",
sp_us = true,
},
["U.S.pt"] = {
target = "USpt",
sp_us = true,
},
["U.S.qt"] = {
target = "USqt",
sp_us = true,
default = "L impqt",
customary= 2,
},
["usbbl"] = {
target = "USbbl",
},
["usbeerbbl"] = {
target = "USbeerbbl",
},
["usbsh"] = {
target = "USbsh",
},
["usbu"] = {
target = "USbu",
},
["usdrybbl"] = {
target = "USdrybbl",
},
["usdrygal"] = {
target = "USdrygal",
},
["usdrypt"] = {
target = "USdrypt",
},
["usdryqt"] = {
target = "USdryqt",
},
["USfloz"] = {
target = "USoz",
},
["usfloz"] = {
target = "USoz",
},
["USGAL"] = {
target = "USgal",
},
["usgal"] = {
target = "USgal",
},
["usgi"] = {
target = "USgi",
},
["uskenning"] = {
target = "USkenning",
},
["usoz"] = {
target = "USoz",
},
["uspk"] = {
target = "USpk",
},
["uspt"] = {
target = "USpt",
},
["usqt"] = {
target = "USqt",
},
["yd3"] = {
target = "cuyd",
},
["cuft/sqmi"] = {
per = { "cuft", "sqmi" },
utype = "volume per unit area",
default = "m3/km2",
},
["m3/ha"] = {
name1 = "cubic metre per hectare",
name1_us = "cubic meter per hectare",
name2 = "cubic metres per hectare",
name2_us = "cubic meters per hectare",
symbol = "m<sup>3</sup>/ha",
utype = "volume per unit area",
scale = 0.0001,
default = "USbu/acre",
link = "Hectare",
},
["m3/km2"] = {
per = { "m3", "km2" },
utype = "volume per unit area",
default = "cuft/sqmi",
},
["U.S.gal/acre"] = {
per = { "U.S.gal", "acre" },
utype = "volume per unit area",
default = "m3/km2",
},
["USbu/acre"] = {
name2 = "US bushels per acre",
symbol = "US bushel per acre",
usename = 1,
utype = "volume per unit area",
scale = 8.7077638761350888e-6,
default = "m3/ha",
link = "Bushel",
},
["USgal/acre"] = {
per = { "USgal", "acre" },
utype = "volume per unit area",
default = "m3/km2",
},
["cuyd/mi"] = {
per = { "cuyd", "mi" },
utype = "volume per unit length",
default = "m3/km",
},
["m3/km"] = {
per = { "m3", "km" },
utype = "volume per unit length",
default = "cuyd/mi",
},
["mich"] = {
combination= { "ch", "mi" },
multiple = { 80 },
utype = "length",
},
["michlk"] = {
combination= { "chlk", "mi" },
multiple = { 80 },
utype = "length",
},
["michainlk"] = {
combination= { "chainlk", "mi" },
multiple = { 80 },
utype = "length",
},
["miyd"] = {
combination= { "yd", "mi" },
multiple = { 1760 },
utype = "length",
},
["miydftin"] = {
combination= { "in", "ft", "yd", "mi" },
multiple = { 12, 3, 1760 },
utype = "length",
},
["mift"] = {
combination= { "ft", "mi" },
multiple = { 5280 },
utype = "length",
},
["ydftin"] = {
combination= { "in", "ft", "yd" },
multiple = { 12, 3 },
utype = "length",
},
["ydft"] = {
combination= { "ft", "yd" },
multiple = { 3 },
utype = "length",
},
["ftin"] = {
combination= { "in", "ft" },
multiple = { 12 },
utype = "length",
},
["footin"] = {
combination= { "in", "foot" },
multiple = { 12 },
utype = "length",
},
["handin"] = {
combination= { "in", "hand" },
multiple = { 4 },
utype = "length",
},
["lboz"] = {
combination= { "oz", "lb" },
multiple = { 16 },
utype = "mass",
},
["stlb"] = {
combination= { "lb", "st" },
multiple = { 14 },
utype = "mass",
},
["stlboz"] = {
combination= { "oz", "lb", "st" },
multiple = { 16, 14 },
utype = "mass",
},
["st and lb"] = {
combination= { "lb", "st" },
multiple = { 14 },
utype = "mass",
},
["GN LTf"] = {
combination= { "GN", "-LTf" },
utype = "force",
},
["GN LTf STf"] = {
combination= { "GN", "-LTf", "-STf" },
utype = "force",
},
["GN STf"] = {
combination= { "GN", "-STf" },
utype = "force",
},
["GN STf LTf"] = {
combination= { "GN", "-STf", "-LTf" },
utype = "force",
},
["kN LTf"] = {
combination= { "kN", "-LTf" },
utype = "force",
},
["kN LTf STf"] = {
combination= { "kN", "-LTf", "-STf" },
utype = "force",
},
["kN STf"] = {
combination= { "kN", "-STf" },
utype = "force",
},
["kN STf LTf"] = {
combination= { "kN", "-STf", "-LTf" },
utype = "force",
},
["LTf STf"] = {
combination= { "-LTf", "-STf" },
utype = "force",
},
["MN LTf"] = {
combination= { "MN", "-LTf" },
utype = "force",
},
["MN LTf STf"] = {
combination= { "MN", "-LTf", "-STf" },
utype = "force",
},
["MN STf"] = {
combination= { "MN", "-STf" },
utype = "force",
},
["MN STf LTf"] = {
combination= { "MN", "-STf", "-LTf" },
utype = "force",
},
["STf LTf"] = {
combination= { "-STf", "-LTf" },
utype = "force",
},
["L/100 km mpgimp"] = {
combination= { "L/100 km", "mpgimp" },
utype = "fuel efficiency",
},
["l/100 km mpgimp"] = {
combination= { "l/100 km", "mpgimp" },
utype = "fuel efficiency",
},
["L/100 km mpgUS"] = {
combination= { "L/100 km", "mpgus" },
utype = "fuel efficiency",
},
["L/100 km mpgus"] = {
combination= { "L/100 km", "mpgus" },
utype = "fuel efficiency",
},
["l/100 km mpgus"] = {
combination= { "l/100 km", "mpgus" },
utype = "fuel efficiency",
},
["mpgimp L/100 km"] = {
combination= { "mpgimp", "L/100 km" },
utype = "fuel efficiency",
},
["LT ST t"] = {
combination= { "lt", "-ST", "t" },
utype = "mass",
},
["LT t ST"] = {
combination= { "lt", "t", "-ST" },
utype = "mass",
},
["ST LT t"] = {
combination= { "-ST", "lt", "t" },
utype = "mass",
},
["ST t LT"] = {
combination= { "-ST", "t", "lt" },
utype = "mass",
},
["t LT ST"] = {
combination= { "t", "lt", "-ST" },
utype = "mass",
},
["ton"] = {
combination= { "LT", "ST" },
utype = "mass",
},
["kPa kg/cm2"] = {
combination= { "kPa", "kgf/cm2" },
utype = "pressure",
},
["kPa lb/in2"] = {
combination= { "kPa", "-lb/in2" },
utype = "pressure",
},
["floz"] = {
combination= { "impoz", "USoz" },
utype = "volume",
},
}
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local default_exceptions = {
-- Prefixed units with a default different from that of the base unit.
-- Each key item is a prefixed symbol (unitcode for engineering notation).
["cm<sup>2</sup>"] = "sqin",
["dm<sup>2</sup>"] = "sqin",
["e3acre"] = "km2",
["e3m2"] = "e6sqft",
["e6acre"] = "km2",
["e6ha"] = "e6acre",
["e6km2"] = "e6sqmi",
["e6m2"] = "e6sqft",
["e6sqft"] = "v * 9.290304 < 100 ! e3 ! e6 ! m2",
["e6sqmi"] = "e6km2",
["hm<sup>2</sup>"] = "acre",
["km<sup>2</sup>"] = "sqmi",
["mm<sup>2</sup>"] = "sqin",
["aJ"] = "eV",
["e3BTU"] = "MJ",
["e6BTU"] = "GJ",
["EJ"] = "kWh",
["fJ"] = "keV",
["GJ"] = "kWh",
["MJ"] = "kWh",
["PJ"] = "kWh",
["pJ"] = "MeV",
["TJ"] = "kWh",
["YJ"] = "kWh",
["yJ"] = "μeV",
["ZJ"] = "kWh",
["zJ"] = "meV",
["e12cuft/a"] = "v * 2.8316846592 < 100 ! e9 ! e12 ! m3/a",
["e12cuft/d"] = "v * 2.8316846592 < 100 ! e9 ! e12 ! m3/d",
["e12m3/a"] = "Tcuft/a",
["e12m3/d"] = "Tcuft/d",
["e3cuft/a"] = "v * 2.8316846592 < 100 ! ! e3 ! m3/a",
["e3cuft/d"] = "v * 2.8316846592 < 100 ! ! e3 ! m3/d",
["e3cuft/s"] = "v * 2.8316846592 < 100 ! ! e3 ! m3/s",
["e3m3/a"] = "v < 28.316846592 ! k ! M ! cuft/a",
["e3m3/d"] = "v < 28.316846592 ! k ! M ! cuft/d",
["e3m3/s"] = "v < 28.316846592 ! k ! M ! cuft/s",
["e3USgal/a"] = "v * 3.785411784 < 1000 ! ! e3 ! m3/a",
["e6cuft/a"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3/a",
["e6cuft/d"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3/d",
["e6cuft/s"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3/s",
["e6m3/a"] = "v < 28.316846592 ! M ! G ! cuft/a",
["e6m3/d"] = "v < 28.316846592 ! M ! G ! cuft/d",
["e6m3/s"] = "v < 28.316846592 ! e6 ! e9 ! cuft/s",
["e6USgal/a"] = "v * 3.785411784 < 1000 ! e3 ! e6 ! m3/a",
["e9cuft/a"] = "m3/a",
["e9cuft/d"] = "v * 2.8316846592 < 100 ! e6 ! e9 ! m3/d",
["e9m3/a"] = "v < 28.316846592 ! G ! T ! cuft/a",
["e9m3/d"] = "v < 28.316846592 ! G ! T ! cuft/d",
["e9m3/s"] = "v < 28.316846592 ! e9 ! e12 ! cuft/s",
["e9USgal/a"] = "v * 3.785411784 < 1000 ! e6 ! e9 ! m3/a",
["e9USgal/s"] = "v * 3.785411784 < 1000 ! e6 ! e9 ! m3/s",
["nN"] = "gr-f",
["μN"] = "gr-f",
["mN"] = "oz-f",
["am"] = "in",
["cm"] = "in",
["dam"] = "ft",
["dm"] = "in",
["e12km"] = "e12mi",
["e12mi"] = "e12km",
["e3AU"] = "ly",
["e3km"] = "e3mi",
["e3mi"] = "e3km",
["e6km"] = "e6mi",
["e6mi"] = "e6km",
["e9km"] = "AU",
["e9mi"] = "e9km",
["Em"] = "mi",
["fm"] = "in",
["Gm"] = "mi",
["hm"] = "ft",
["km"] = "mi",
["mm"] = "in",
["Mm"] = "mi",
["nm"] = "in",
["Pm"] = "mi",
["pm"] = "in",
["Tm"] = "mi",
["Ym"] = "mi",
["ym"] = "in",
["Zm"] = "mi",
["zm"] = "in",
["μm"] = "in",
["e12lb"] = "v * 4.5359237 < 10 ! Mt ! Gt",
["e3lb"] = "v * 4.5359237 < 10 ! kg ! t",
["e3ozt"] = "v * 0.311034768 < 10 ! kg ! t",
["e3t"] = "LT ST",
["e6carat"] = "t",
["e6lb"] = "v * 4.5359237 < 10 ! t ! kilotonne",
["e6ozt"] = "lb kg",
["e6ST"] = "Mt",
["e6t"] = "LT ST",
["e9lb"] = "v * 4.5359237 < 10 ! kilotonne ! Mt",
["e9t"] = "LT ST",
["Gg"] = "lb",
["kg"] = "lb",
["mg"] = "gr",
["Mg"] = "LT ST",
["ng"] = "gr",
["μg"] = "gr",
["mBq"] = "fCi",
["kBq"] = "nCi",
["MBq"] = "μCi",
["GBq"] = "mCi",
["TBq"] = "Ci",
["PBq"] = "kCi",
["EBq"] = "kCi",
["fCi"] = "mBq",
["pCi"] = "Bq",
["nCi"] = "Bq",
["μCi"] = "kBq",
["mCi"] = "MBq",
["kCi"] = "TBq",
["MCi"] = "PBq",
["ns"] = "μs",
["μs"] = "ms",
["ms"] = "s",
["ks"] = "h",
["Ms"] = "week",
["Gs"] = "decade",
["Ts"] = "millennium",
["Ps"] = "million year",
["Es"] = "thousand million year",
["MK"] = "keVT",
["cL"] = "impoz usoz",
["cl"] = "impoz usoz",
["cm<sup>3</sup>"] = "cuin",
["dL"] = "impoz usoz",
["dl"] = "impoz usoz",
["mm<sup>3</sup>"] = "cuin",
["dm<sup>3</sup>"] = "cuin",
["e12cuft"] = "v * 2.8316846592 < 100 ! e9 ! e12 ! m3",
["e12impgal"] = "v * 4.54609 < 1000 ! T ! P ! l",
["e12m3"] = "v < 28.316846592 ! T ! P ! cuft",
["e12U.S.gal"] = "v * 3.785411784 < 1000 ! T ! P ! l",
["e12USgal"] = "v * 3.785411784 < 1000 ! T ! P ! l",
["e15cuft"] = "v * 2.8316846592 < 100 ! e12 ! e15 ! m3",
["e15m3"] = "Pcuft",
["e3bdft"] = "v * 0.23597372167 < 100 ! e3 ! e6 ! m3",
["e3cuft"] = "v * 2.8316846592 < 100 ! ! e3 ! m3",
["e3impgal"] = "v * 4.54609 < 1000 ! k ! M ! l",
["e3m3"] = "v < 28.316846592 ! k ! M ! cuft",
["e3U.S.gal"] = "v * 3.785411784 < 1000 ! k ! M ! l",
["e3USgal"] = "v * 3.785411784 < 1000 ! k ! M ! l",
["e6bdft"] = "v * 0.23597372167 < 100 ! e3 ! e6 ! m3",
["e6cuft"] = "v * 2.8316846592 < 100 ! e3 ! e6 ! m3",
["e6cuyd"] = "v * 7.64554857984 < 10 ! e3 ! e6 ! m3",
["e6impgal"] = "v * 4.54609 < 1000 ! M ! G ! l",
["e6L"] = "USgal",
["e6m3"] = "v < 28.316846592 ! M ! G ! cuft",
["e6U.S.gal"] = "v * 3.785411784 < 1000 ! M ! G ! l",
["e6USgal"] = "v * 3.785411784 < 1000 ! M ! G ! l",
["e9bdft"] = "v * 0.23597372167 < 100 ! e6 ! e9 ! m3",
["e9cuft"] = "v * 2.8316846592 < 100 ! e6 ! e9 ! m3",
["e9impgal"] = "v * 4.54609 < 1000 ! G ! T ! l",
["e9m3"] = "v < 28.316846592 ! G ! T ! cuft",
["e9U.S.gal"] = "v * 3.785411784 < 1000 ! G ! T ! l",
["e9USgal"] = "v * 3.785411784 < 1000 ! G ! T ! l",
["GL"] = "cuft",
["Gl"] = "cuft",
["kL"] = "cuft",
["kl"] = "cuft",
["km<sup>3</sup>"] = "cumi",
["mL"] = "impoz usoz",
["ml"] = "impoz usoz",
["Ml"] = "v < 28.316846592 ! e3 ! e6 ! cuft",
["ML"] = "v < 28.316846592 ! e3 ! e6 ! cuft",
["TL"] = "cumi",
["Tl"] = "cumi",
["μL"] = "cuin",
["μl"] = "cuin",
}
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local link_exceptions = {
-- Prefixed units with a linked article different from that of the base unit.
-- Each key item is a prefixed symbol (not unitcode).
["mm<sup>2</sup>"] = "Square millimetre",
["cm<sup>2</sup>"] = "Square centimetre",
["dm<sup>2</sup>"] = "Square decimetre",
["km<sup>2</sup>"] = "Square kilometre",
["kJ"] = "Kilojoule",
["MJ"] = "Megajoule",
["GJ"] = "Gigajoule",
["TJ"] = "Terajoule",
["fm"] = "Femtometre",
["pm"] = "Picometre",
["nm"] = "Nanometre",
["μm"] = "Micrometre",
["mm"] = "Millimetre",
["cm"] = "Centimetre",
["dm"] = "Decimetre",
["dam"] = "Decametre",
["hm"] = "Hectometre",
["km"] = "Kilometre",
["Mm"] = "Megametre",
["Gm"] = "Gigametre",
["Tm"] = "Terametre",
["Pm"] = "Petametre",
["Em"] = "Exametre",
["Zm"] = "Zettametre",
["Ym"] = "Yottametre",
["μg"] = "Microgram",
["mg"] = "Milligram",
["kg"] = "Kilogram",
["Mg"] = "Tonne",
["yW"] = "Yoctowatt",
["zW"] = "Zeptowatt",
["aW"] = "Attowatt",
["fW"] = "Femtowatt",
["pW"] = "Picowatt",
["nW"] = "Nanowatt",
["μW"] = "Microwatt",
["mW"] = "Milliwatt",
["kW"] = "Kilowatt",
["MW"] = "Megawatt",
["GW"] = "Gigawatt",
["TW"] = "Terawatt",
["PW"] = "Petawatt",
["EW"] = "Exawatt",
["ZW"] = "Zettawatt",
["YW"] = "Yottawatt",
["as"] = "Attosecond",
["fs"] = "Femtosecond",
["ps"] = "Picosecond",
["ns"] = "Nanosecond",
["μs"] = "Microsecond",
["ms"] = "Millisecond",
["ks"] = "Kilosecond",
["Ms"] = "Megasecond",
["Gs"] = "Gigasecond",
["Ts"] = "Terasecond",
["Ps"] = "Petasecond",
["Es"] = "Exasecond",
["Zs"] = "Zettasecond",
["Ys"] = "Yottasecond",
["mm<sup>3</sup>"] = "Cubic millimetre",
["cm<sup>3</sup>"] = "Cubic centimetre",
["dm<sup>3</sup>"] = "Cubic decimetre",
["dam<sup>3</sup>"] = "Cubic decametre",
["km<sup>3</sup>"] = "Cubic kilometre",
["μL"] = "Microlitre",
["μl"] = "Microlitre",
["mL"] = "Millilitre",
["ml"] = "Millilitre",
["cL"] = "Centilitre",
["cl"] = "Centilitre",
["dL"] = "Decilitre",
["dl"] = "Decilitre",
["daL"] = "Decalitre",
["dal"] = "Decalitre",
["hL"] = "Hectolitre",
["hl"] = "Hectolitre",
["kL"] = "Kilolitre",
["kl"] = "Kilolitre",
["ML"] = "Megalitre",
["Ml"] = "Megalitre",
["GL"] = "Gigalitre",
["Gl"] = "Gigalitre",
["TL"] = "Teralitre",
["Tl"] = "Teralitre",
["PL"] = "Petalitre",
["Pl"] = "Petalitre",
}
---------------------------------------------------------------------------
-- Do not change the data in this table because it is created by running --
-- a script that reads the wikitext from a wiki page (see note above). --
---------------------------------------------------------------------------
local per_unit_fixups = {
-- Automatically created per units of form "x/y" may have their unit type
-- changed, for example, "length/time" is changed to "speed".
-- Other adjustments can also be specified.
["/area"] = "per unit area",
["/volume"] = "per unit volume",
["area/area"] = "area per unit area",
["energy/length"] = "energy per unit length",
["energy/mass"] = "energy per unit mass",
["energy/time"] = { utype = "power", link = "Power (physics)" },
["energy/volume"] = "energy per unit volume",
["force/area"] = { utype = "pressure", link = "Pressure" },
["length/length"] = { utype = "gradient", link = "Grade (slope)" },
["length/time"] = { utype = "speed", link = "Speed" },
["length/time/time"] = { utype = "acceleration", link = "Acceleration" },
["mass/area"] = { utype = "pressure", multiplier = 9.80665 },
["mass/length"] = "linear density",
["mass/mass"] = "concentration",
["mass/power"] = "mass per unit power",
["mass/time"] = "mass per unit time",
["mass/volume"] = { utype = "density", link = "Density" },
["power/mass"] = "power per unit mass",
["power/volume"] = { link = "Power density" },
["pressure/length"] = "fracture gradient",
["speed/time"] = { utype = "acceleration", link = "Acceleration" },
["volume/area"] = "volume per unit area",
["volume/length"] = "volume per unit length",
["volume/time"] = "flow",
}
return {
all_units = all_units,
default_exceptions = default_exceptions,
link_exceptions = link_exceptions,
per_unit_fixups = per_unit_fixups,
}
69cd04fba2962c152d0008b00cb8b7df57549e07
Module:Convert/text
828
722
1108
1107
2025-08-22T00:55:51Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Text used by Module:Convert for enwiki.
-- This is a separate module to simplify translation for use on another wiki.
-- See [[:en:Template:Convert/Transwiki guide]] if copying to another wiki.
-- Some units accept an SI prefix before the unit code, such as "kg" for kilogram.
local SIprefixes = {
-- The prefix field is what the prefix should be, if different from the prefix used.
['Q'] = { exponent = 30, name = 'quetta', },
['R'] = { exponent = 27, name = 'ronna', },
['Y'] = { exponent = 24, name = 'yotta', },
['Z'] = { exponent = 21, name = 'zetta', },
['E'] = { exponent = 18, name = 'exa' , },
['P'] = { exponent = 15, name = 'peta' , },
['T'] = { exponent = 12, name = 'tera' , },
['G'] = { exponent = 9, name = 'giga' , },
['M'] = { exponent = 6, name = 'mega' , },
['k'] = { exponent = 3, name = 'kilo' , },
['h'] = { exponent = 2, name = 'hecto', },
['da']= { exponent = 1, name = 'deca' , name_us = 'deka' },
['d'] = { exponent = -1, name = 'deci' , },
['c'] = { exponent = -2, name = 'centi', },
['m'] = { exponent = -3, name = 'milli', },
['μ'] = { exponent = -6, name = 'micro', }, -- key = 'GREEK SMALL LETTER MU' (U+03BC) utf-8 CE BC
['µ'] = { exponent = -6, name = 'micro', prefix = 'μ' }, -- key = 'MICRO SIGN' (U+00B5) utf-8 C2 B5
['u'] = { exponent = -6, name = 'micro', prefix = 'μ' }, -- not an SI prefix, but allow for people typing this
['n'] = { exponent = -9, name = 'nano' , },
['p'] = { exponent =-12, name = 'pico' , },
['f'] = { exponent =-15, name = 'femto', },
['a'] = { exponent =-18, name = 'atto' , },
['z'] = { exponent =-21, name = 'zepto', },
['y'] = { exponent =-24, name = 'yocto', },
['r'] = { exponent =-27, name = 'ronto', },
['q'] = { exponent =-30, name = 'quecto', },
}
-- Some units can be qualified with one of the following prefixes, when linked.
local customary_units = {
{ "US", link = "United States customary units" },
{ "U.S.", link = "United States customary units" },
{ "imperial", link = "Imperial units" },
{ "imp", link = "Imperial units" },
}
-- Names when using engineering notation (a prefix of "eN" where N is a number; example "e6km").
-- key = { "name", link = "article title", exponent = numeric_key_value }
-- If lk=on and link is defined, the name of the number will appear as a link.
local eng_scales = {
["3"] = { "thousand", exponent = 3 },
["6"] = { "million", exponent = 6 },
["9"] = { "billion", link = "1000000000 (number)", exponent = 9 },
["12"] = { "trillion", link = "1000000000000 (number)", exponent = 12 },
["15"] = { "quadrillion", link = "1000000000000000 (number)", exponent = 15 },
}
local all_categories = {
unit = "[[Category:Convert errors]]",
option = "[[Category:Convert errors]]",
warning = '[[Category:Convert invalid options]]',
tracking = '[[Category:Convert tracking]]',
}
-- For some error messages, the following puts the wanted style around
-- each unit code marked like '...%{ft%}...'.
local unitcode_regex = '%%([{}])'
local unitcode_replace = { ['{'] = '"', ['}'] = '"' } -- no longer need the more elaborate substitute used before 2013-09-28
-- All messages that may be displayed if a problem occurs.
local all_messages = {
-- Message format string: $1=title, $2=text, $3=category, $4=anchor.
-- Each displayed message starts with "Convert:" so can easily locate by searching article.
cvt_format = '<sup class="noprint Inline-Template" style="white-space:nowrap;">[<i>[[Help:Convert messages#$4|<span title="Convert: $1">convert: $2</span>]]</i>]</sup>$3<span class="error"></span>',
cvt_format2 = '<sup class="noprint Inline-Template" style="white-space:nowrap;">[[Help:Convert messages#$4|<span title="Convert: $1">$2</span>]]</sup>$3<span class="error"></span>',
cvt_format_preview = '<strong class="error">Error in convert: $1 [[Help:Convert messages#$4|(help)]]</strong>$3',
-- Each of following messages is a table:
-- { [1] = 'title', -- mouseover title text
-- [2] = 'text', -- link text displayed in article
-- [3] = 'category key', -- key to lookup category in all_categories
-- [4] = 'anchor', -- anchor for link to relevant section on help page
-- regex = gsub_regex,
-- replace = gsub_table,
-- } Mouseover title text Link text CatKey Anchor
cvt_bad_input = { 'input "$1" must be a number and unit' , 'invalid input' , 'option', 'invalid_input' },
cvt_bad_num = { 'Value "$1" must be a number' , 'invalid number' , 'option', 'invalid_number' },
cvt_big_prec = { 'Precision "$1" is too large' , 'precision too large' , 'option', 'precision_too_large' },
cvt_invalid_num = { 'Number has overflowed' , 'number overflow' , 'option', 'number_overflow' },
cvt_no_num = { 'Needs the number to be converted' , 'needs a number' , 'option', 'needs_number' },
cvt_no_num2 = { 'Needs another number for a range' , 'needs another number', 'option', 'needs_another_number' },
cvt_bad_altitude = { '"$1" needs an integer' , 'invalid altitude' , 'option', 'invalid_altitude' },
cvt_bad_frac = { '"$1" needs an integer above 1' , 'invalid fraction' , 'option', 'invalid_fraction' },
cvt_bad_prec = { 'Precision "$1" must be an integer' , 'invalid precision' , 'option', 'invalid_precision' },
cvt_bad_sigfig = { '"$1" needs a positive integer' , 'invalid sigfig' , 'option', 'invalid_sigfig' },
cvt_empty_option = { 'Ignored empty option "$1"' , 'empty option' , 'option', 'empty_option' },
cvt_deprecated = { 'Option "$1" is deprecated' , '*' , 'option', 'deprecated_option', format = 'cvt_format2', nowarn = true },
cvt_no_spell = { 'Spelling is not available' , 'bug, ask for help' , 'option', 'ask_for_help' },
cvt_unknown_option = { 'Ignored invalid option "$1"' , 'invalid option' , 'option', 'invalid_option' },
cvt_wd_fail = { 'Unable to access Wikidata' , 'wikidata problem' , 'option', 'wikidata_problem' },
cvt_bad_default = { 'Unit "$1" has an invalid default' , 'bug, ask for help' , 'unit' , 'ask_for_help' },
cvt_bad_unit = { 'Unit "$1" is invalid here' , 'unit invalid here' , 'unit' , 'unit_invalid_here' },
cvt_no_default = { 'Unit "$1" has no default output unit' , 'bug, ask for help' , 'unit' , 'ask_for_help' },
cvt_no_unit = { 'Needs name of unit' , 'needs unit name' , 'unit' , 'needs_unit_name' },
cvt_unknown = { 'Unit name "$1" is not known' , 'unknown unit' , 'unit' , 'unknown_unit' },
cvt_should_be = { '$1' , 'ambiguous unit' , 'unit' , 'ambiguous_unit', regex = unitcode_regex, replace = unitcode_replace },
cvt_mismatch = { 'Cannot convert "$1" to "$2"' , 'unit mismatch' , 'unit' , 'unit_mismatch' },
cvt_bug_convert = { 'Bug: Cannot convert between specified units', 'bug, ask for help' , 'unit' , 'ask_for_help' },
cvt_lookup = { 'Unit "$1" is incorrectly defined' , 'bug, ask for help' , 'unit' , 'ask_for_help' },
}
-- Text to join input value/unit with output value/unit.
local disp_joins = {
-- [1]=before output, [2]=after output, [3]=between outputs in a combination; default "; "
-- [wantname] gives default abbr=off
["or"] = { " or " , "" , " or ", wantname = true },
["sqbr-sp"] = { " [" , "]" },
["sqbr-nbsp"] = { " [" , "]" },
["comma"] = { ", " , "" , ", " },
["semicolon"] = { "; " , "" },
["slash-sp"] = { " / " , "" , wantname = true },
["slash-nbsp"] = { " / ", "" , wantname = true },
["slash-nosp"] = { "/" , "" , wantname = true },
["b"] = { " (" , ")" },
["(or)"] = { " (" , ")", " or " },
["br"] = { "<br />" , "" , wantname = true },
["br()"] = { "<br />(" , ")", wantname = true },
}
-- Text to separate values in a range.
local range_types = {
-- Specifying a table requires either:
-- * "off" and "on" values (for "abbr=off" and "abbr=on"), or
-- * "input" and "output" values (for LHS and RHS);
-- other fields are optional.
-- When "adj=on|abbr=off" applies, spaces in range text are replaced with hyphens.
-- With "exception = true", that also occurs with "adj=on|abbr=on".
-- If "adj" is defined here, that text (unchanged) is used with "adj=on".
["+"] = " + ",
[","] = ", ",
[", and"] = ", and ",
[", or"] = ", or ",
["by"] = " by ",
["-"] = "–",
["to about"] = " to about ",
["and"] = { off = " and ", on = " and ", exception = true },
["and(-)"] = { input = " and ", output = "–" },
["or"] = { off = " or " , on = " or " , exception = true },
["to"] = { off = " to " , on = " to " , exception = true },
["to(-)"] = { input = " to ", output = "–" },
["+/-"] = { off = " ± ", on = " ± ", adj = " ± ", is_range_change = true },
["by(x)"] = { input = " by ", output = " × ", out_range_x = true },
["x"] = { off = " by ", on = " × ", abbr_range_x = true },
["xx"] = " × ",
["*"] = "×",
["/"] = " / ", -- for a table of high/low temperatures with {{convert|83|/|63|F|disp=br()|abbr=values}}
}
local range_aliases = {
-- ["alternative name for a range"] = "standard range name"
["–"] = "-",
["–"] = "-",
["×"] = "x",
["×"] = "x",
["±"] = "+/-",
["±"] = "+/-",
}
-- Convert accepts range text delimited with whitespace, for example, {{convert|1 to 2|ft}}.
-- In addition, the following "words" are accepted without spaces, for example, {{convert|1-2|ft}}.
-- Words must be in correct order for searching, for example, 'x' after 'xx'.
local range_words = { '-', '–', 'xx', 'x', '*' }
local ranges = {
types = range_types,
aliases = range_aliases,
words = range_words,
}
-- Valid option names.
local en_option_name = {
-- ["local text for option name"] = "en name used in this module"
["$"] = "$",
["abbr"] = "abbr",
["adj"] = "adj",
["altitude_ft"] = "altitude_ft",
["altitude_m"] = "altitude_m",
["comma"] = "comma",
["debug"] = "debug",
["disp"] = "disp",
["frac"] = "frac",
["input"] = "input",
["lang"] = "lang",
["link"] = "lk",
["lk"] = "lk",
["order"] = "order",
["qid"] = "qid",
["qual"] = "qual",
["qualifier"] = "qual",
["round"] = "round",
["sigfig"] = "sigfig",
["sing"] = "adj", -- "sing" is an old alias for "adj"
["sortable"] = "sortable",
["sp"] = "sp",
["spell"] = "spell",
["stylein"] = "stylein",
["styleout"] = "styleout",
["tracking"] = "tracking",
}
-- Valid option values.
-- Convention: parms.opt_xxx refers to an option that is set here
-- (not intended to be set by the template which invokes this module).
-- Example: At enwiki, "abbr" includes:
-- ["values"] = "opt_values"
-- As a result, if the template uses abbr=values, Module:Convert sets:
-- parms["opt_values"] = true
-- parms["abbr"] = nil
-- Therefore parms.abbr will be nil, or will have one of the listed values
-- that do not start with "opt_".
-- An option value of form "xxx?" is the same as "xxx" but shows the input as deprecated.
-- Options removed in January 2018 with remnants still in Module:Convert:
-- abbr=mos (in a range, repeat the input unit)
-- adj=1 (set opt_singular to make the unit name singular when 0 < abs(value) <= 1)
local en_option_value = {
["$"] = 'TEXT', -- TEXT should be a currency symbol that will be used instead of "$"
["abbr"] = {
-- ["local text for option value"] = "en value used in this module"
["def"] = "", -- ignored (some wrapper templates call convert with "abbr=def" to mean "default abbreviation")
["h"] = "on", -- abbr=on + use "h" for hand unit (default)
["hh"] = "opt_hand_hh", -- abbr=on + use "hh" for hand unit
["in"] = "in", -- use symbol for LHS unit
["none"] = "off", -- old name for "off"
["off"] = "off", -- use name for all units
["on"] = "on", -- use symbol for all units
["out"] = "out", -- use symbol for RHS unit (default)
["unit"] = "unit", -- abbr=on but abbreviate units only: e6km → million km (not ×10⁶ km)
["values"] = "opt_values", -- show only input and output numbers, not units
["~"] = "opt_also_symbol", -- show input unit symbol as well as name
},
["adj"] = {
["mid"] = "opt_adjectival, opt_adj_mid", -- adj=on with user-specified text after input unit (between input and output)
["off"] = "", -- ignored (off is the default)
["on"] = "opt_adjectival", -- unit name is singular and hyphenated
["pre"] = "opt_one_preunit", -- user-specified text before input unit
["ri0"] = "opt_ri=0", -- round input with precision = 0
["ri1"] = "opt_ri=1", -- round input with precision = 1
["ri2"] = "opt_ri=2", -- round input with precision = 2
["ri3"] = "opt_ri=3", -- round input with precision = 3
["~"] = "opt_also_symbol", -- same as abbr=~ so can have {{convert|1|C|K|abbr=off|adj=~}}
},
["altitude_ft"] = 'INTEGER',
["altitude_m"] = 'INTEGER',
["comma"] = {
["5"] = "opt_comma5", -- only use numsep grouping if 5 or more digits
["gaps"] = "opt_gaps", -- use gaps, not numsep, to separate groups of digits
["gaps3"] = "opt_gaps, opt_gaps3", -- group only in threes rather than default of no gap before a single digit after decimal mark
["off"] = "opt_nocomma", -- no numsep in input or output numbers
},
["debug"] = {
["yes"] = "opt_sortable_debug", -- make the normally hidden sort key visible
},
["disp"] = {
["5"] = "opt_round=5?", -- round output value to nearest 5
["b"] = "b", -- join: '(...)'
["(or)"] = "(or)", -- join: '(...)' with 'or' between outputs in a combination
["br"] = "br", -- join: '<br />'
["br()"] = "br()", -- join: '<br />(...)'
["comma"] = "comma", -- join: ','
["flip"] = "opt_flip", -- reverse order of input/output
["number"] = "opt_output_number_only", -- display output value (not input, and not output symbol/name)
["or"] = "or", -- join: 'or'
["out"] = "opt_output_only",
["output number only"] = "opt_output_number_only",
["output only"] = "opt_output_only",
["preunit"] = "opt_two_preunits", -- user-specified text before input and output units
["semicolon"] = "semicolon", -- join: ';'
["sqbr"] = "sqbr", -- join: '[...]'
["table"] = "opt_table", -- output is suitable for a table cell with align="right"
["tablecen"] = "opt_tablecen", -- output is suitable for a table cell with align="center"
["unit"] = "opt_input_unit_only", -- display input symbol/name (not output, and not input value)
["unit or text"] = "opt_input_unit_only, opt_ignore_error", -- display input symbol/name, or given unit code if not known
["unit2"] = "opt_output_unit_only",
["x"] = "x", -- join: <first>...<second> (user-specified text)
},
["frac"] = 'INTEGER',
["input"] = 'TEXT', -- TEXT should be <value><space><unitcode> or <wikidata-property-id>
["lang"] = { -- language for output digits (both en and local digits are always accepted for input)
["en"] = "opt_lang_en", -- use en digits for numbers, regardless of local language
["local"] = "opt_lang_local", -- use local digits for numbers (default, although config can change default to en)
},
["lk"] = {
["in"] = "in", -- link LHS unit name or symbol
["off"] = "off", -- do not link: same as default except for hand unit
["on"] = "on", -- link all unit names or symbols (but not twice for the same unit)
["out"] = "out", -- link RHS unit name or symbol
},
["order"] = {
["flip"] = "opt_flip", -- reverse order of input/output
["out"] = "opt_order_out", -- do not show input; instead, use order in output combination, with the first output shown as the input
},
["qid"] = 'TEXT', -- TEXT should be a Wikidata Q item identifier
["qual"] = 'TEXT', -- TEXT should be a Wikidata Q item identifier
["round"] = {
["0.5"] = "opt_round=0.5", -- round output value to nearest 0.5
["5"] = "opt_round=5", -- round output value to nearest 5
["10"] = "opt_round=10", -- round output value to nearest 10 (same as but clearer than "|-1")
["25"] = "opt_round=25", -- round output value to nearest 25
["50"] = "opt_round=50", -- round output value to nearest 50
["each"] = "opt_round_each", -- using default precision in a range, round each output separately (default uses highest precision of each item in range)
},
["sigfig"] = 'INTEGER',
["sortable"] = {
["off"] = "", -- ignored (off is the default)
["on"] = "opt_sortable_on", -- output sort key for use in a sortable table, based on value from converting to a standard base unit
["debug"] = "opt_sortable_on, opt_sortable_debug", -- |sortable=debug is the same as |sortable=on|debug=yes
},
["sp"] = {
["us"] = "opt_sp_us", -- use U.S. spelling (like "meter" instead of default "metre")
},
["spell"] = { -- only English spelling is supported; not scientific notation; only some fractions
["in"] = "opt_spell_in", -- spell input value in words
["In"] = "opt_spell_in, opt_spell_upper", -- spell input value in words with first letter uppercase
["on"] = "opt_spell_in, opt_spell_out", -- spell input and output values in words
["On"] = "opt_spell_in, opt_spell_out, opt_spell_upper", -- same, with first letter of first word in result uppercase
["us"] = "opt_sp_us", -- use U.S. spelling; same as sp=us so spell=us also works
},
["stylein"] = 'TEXT',
["styleout"] = 'TEXT',
["tracking"] = 'TEXT',
}
local titles = {
["frac"] = "Fraction/styles.css",
["sfrac"] = "Sfrac/styles.css",
}
return {
SIprefixes = SIprefixes,
all_categories = all_categories,
all_messages = all_messages,
currency = { ['$'] = true, ['£'] = true, ['€'] = true, ['₱'] = true, ['₽'] = true, ['¥'] = true },
customary_units = customary_units,
disp_joins = disp_joins,
en_option_name = en_option_name,
en_option_value = en_option_value,
eng_scales = eng_scales,
ranges = ranges,
titles = titles,
}
d9f24f7b3c125178aa827b8e2b4ad1e7ba143f48
Module:Convert/wikidata
828
723
1110
1109
2025-08-22T00:55:51Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Functions to access Wikidata for Module:Convert.
local Collection = {}
Collection.__index = Collection
do
function Collection:add(item)
if item ~= nil then
self.n = self.n + 1
self[self.n] = item
end
end
function Collection:join(sep)
return table.concat(self, sep)
end
function Collection:remove(pos)
if self.n > 0 and (pos == nil or (0 < pos and pos <= self.n)) then
self.n = self.n - 1
return table.remove(self, pos)
end
end
function Collection:sort(comp)
table.sort(self, comp)
end
function Collection.new()
return setmetatable({n = 0}, Collection)
end
end
local function strip_to_nil(text)
-- If text is a non-empty string, return its trimmed content,
-- otherwise return nothing (empty string or not a string).
if type(text) == 'string' then
return text:match('(%S.-)%s*$')
end
end
local function frequency_unit(value, unit_table)
-- For use when converting m to Hz.
-- Return true, s where s = name of unit's default output unit,
-- or return false, t where t is an error message table.
-- However, for simplicity a valid result is always returned.
local unit
if unit_table._symbol == 'm' then
-- c = speed of light in a vacuum = 299792458 m/s
-- frequency = c / wavelength
local w = value * (unit_table.scale or 1)
local f = 299792458 / w -- if w == 0, f = math.huge which works here
if f >= 1e12 then
unit = 'THz'
elseif f >= 1e9 then
unit = 'GHz'
elseif f >= 1e6 then
unit = 'MHz'
elseif f >= 1e3 then
unit = 'kHz'
else
unit = 'Hz'
end
end
return true, unit or 'Hz'
end
local function wavelength_unit(value, unit_table)
-- Like frequency_unit but for use when converting Hz to m.
local unit
if unit_table._symbol == 'Hz' then
-- Using 0.9993 rather than 1 avoids rounding which would give results
-- like converting 300 MHz to 100 cm instead of 1 m.
local w = 1 / (value * (unit_table.scale or 1)) -- Hz scale is inverted
if w >= 0.9993e6 then
unit = 'Mm'
elseif w >= 0.9993e3 then
unit = 'km'
elseif w >= 0.9993 then
unit = 'm'
elseif w >= 0.9993e-2 then
unit = 'cm'
elseif w >= 0.9993e-3 then
unit = 'mm'
else
unit = 'um'
end
end
return true, unit or 'm'
end
local specials = {
frequency = { frequency_unit },
wavelength = { wavelength_unit },
--------------------------------------------------------------------------------
-- Following is a removed experiment to show two values as a range
-- using '-' as the separator.
-- frequencyrange = { frequency_unit, '-' },
-- wavelengthrange = { wavelength_unit, '-' },
}
local function make_unit(units, parms, uid)
-- Return a unit code for convert or nil if unit unknown.
-- If necessary, add a dummy unit to parms so convert will use it
-- for the input without attempting a conversion since nothing
-- useful is available (for example, with unit volt).
local unit = units[uid]
if type(unit) ~= 'table' then
return nil
end
local ucode = unit.ucode
if ucode and not unit.si then
return ucode -- a unit known to convert
end
parms.opt_ignore_error = true
ucode = ucode or unit._ucode -- must be a non-empty string
local ukey, utable
if unit.si then
local base = units[unit.si]
ukey = base.symbol -- must be a non-empty string
local n1 = base.name1
local n2 = base.name2
if not n1 then
n1 = ukey
n2 = n2 or n1 -- do not append 's'
end
utable = {
_symbol = ukey,
_name1 = n1,
_name2 = n2,
link = unit.link or base.link,
utype = n1,
prefixes = 1,
}
else
ukey = ucode
utable = {
symbol = ucode, -- must be a non-empty string
name1 = unit.name1, -- if nil, uses symbol
name2 = unit.name2, -- if nil, uses name1..'s'
link = unit.link, -- if nil, uses name1
utype = unit.name1 or ucode,
}
end
utable.scale = 1
utable.default = ''
utable.defkey = ''
utable.linkey = ''
utable.bad_mcode = ''
parms.unittable = { [ukey] = utable }
return ucode
end
local function matches_qualifier(statement, qual)
-- Return:
-- false, nil : if statement does not match specification
-- true, nil : if matches, and statement has no qualifier
-- true, sq : if matches, where sq is the statement's qualifier
-- A match means that no qualifier was specified (qual == nil), or that
-- the statement has a qualifier matching the specification.
-- If a match occurs, the caller needs the statement's qualifier (if any)
-- so statements that duplicate the qualifier are not used, after the first.
-- Then, if convert is showing all values for a property such as the diameter
-- of a telescope's mirror (diameters of primary and secondary mirrors), it
-- will not show alternative values that could in principle be present for the
-- same item (telescope) and property (diameter) and qualifier (primary/secondary).
local target = (statement.qualifiers or {}).P518 -- P518 is "applies to part"
if type(target) == 'table' then
for _, q in ipairs(target) do
if type(q) == 'table' then
local value = (q.datavalue or {}).value
if value then
if qual == nil or qual == value.id then
return true, value.id
end
end
end
end
end
if qual == nil then
return true, nil -- only occurs if statement has no qualifier
end
return false, nil -- statement's qualifier is not relevant because statement will be skipped
end
local function get_statements(parms, pid)
-- Get specified item and return a list of tables with each statement for property pid.
-- Each table is of form {statqual=sq, stmt=statement} where sq = statement qualifier (nil if none).
-- Statements are in Wikidata's order except that those with preferred rank
-- are first, then normal rank. Any other rank is ignored.
local stored = {} -- qualifiers of statements that are first for the qualifier, and will be returned
local qid = strip_to_nil(parms.qid) -- nil for current page's item, or an item id (expensive)
local qual = strip_to_nil(parms.qual) -- nil or id of wanted P518 (applies to part) item in qualifiers
local result = Collection.new()
local entity = mw.wikibase.getEntity(qid)
if type(entity) == 'table' then
local statements = (entity.claims or {})[pid]
if type(statements) == 'table' then
for _, rank in ipairs({ 'preferred', 'normal' }) do
for _, statement in ipairs(statements) do
if type(statement) == 'table' and rank == statement.rank then
local is_match, statqual = matches_qualifier(statement, qual)
if is_match then
result:add({ statqual = statqual, stmt = statement })
end
end
end
end
end
end
return result
end
local function input_from_property(tdata, parms, pid)
-- Given that pid is a Wikidata property identifier like 'P123',
-- return a collection of {amount, ucode} pairs (two strings)
-- for each matching item/property, or return nothing.
--------------------------------------------------------------------------------
-- There appear to be few restrictions on how Wikidata is organized so it is
-- very likely that any decision a module makes about how to handle data
-- will be wrong for some cases at some time. This meets current requirements.
-- For each qualifier (or if no qualifier), if there are any preferred
-- statements, use them and ignore any normal statements.
-- For each qualifier, for the preferred statements if any, or for
-- the normal statements (but not both):
-- * Accept each statement if it has no qualifier (this will not occur
-- if qual=x is specified because other code already ensures that in that
-- case, only statements with a qualifier matching x are considered).
-- * Ignore any statements after the first if it has a qualifier.
-- The rationale is that for the diameter at [[South Pole Telescope]], want
-- convert to show the diameters for both the primary and secondary mirrors
-- if the convert does not specify which diameter is wanted.
-- However, if convert is given the wanted qualifier, only one value
-- (_the_ diameter) is wanted. For simplicity/consistency, that is also done
-- even if no qual=x is specified. Unclear what should happen.
-- For the wavelength at [[Nançay Radio Telescope]], want to show all three
-- values, and the values have no qualifiers.
--------------------------------------------------------------------------------
local result = Collection.new()
local done = {}
local skip_normal
for _, t in ipairs(get_statements(parms, pid)) do
local statement = t.stmt
if statement.mainsnak and statement.mainsnak.datatype == 'quantity' then
local value = (statement.mainsnak.datavalue or {}).value
if value then
local amount = value.amount
if amount then
amount = tostring(amount) -- in case amount is ever a number
if amount:sub(1, 1) == '+' then
amount = amount:sub(2)
end
local unit = value.unit
if type(unit) == 'string' then
unit = unit:match('Q%d+$') -- unit item id is at end of URL
local ucode = make_unit(tdata.wikidata_units, parms, unit)
if ucode then
local skip
if t.statqual then
if done[t.statqual] then
skip = true
else
done[t.statqual] = true
end
else
if statement.rank == 'preferred' then
skip_normal = true
elseif skip_normal then
skip = true
end
end
if not skip then
result:add({ amount, ucode })
end
end
end
end
end
end
end
return result
end
local function input_from_text(tdata, parms, text, insert2)
-- Given string should be of form "<value><space><unit>" or
-- "<value1><space>ft<space><value2><space>in" for a special case (feet and inches).
-- Return true if values/units were extracted and inserted, or return nothing.
text = text:gsub(' ', ' '):gsub('%s+', ' ')
local pos = text:find(' ', 1, true)
if pos then
-- Leave checking of value to convert which can handle fractions.
local value = text:sub(1, pos - 1)
local uid = text:sub(pos + 1)
if uid:sub(1, 3) == 'ft ' and uid:sub(-3) == ' in' then
-- Special case for enwiki to allow {{convert|input=5 ft 10+1/2 in}}
insert2(uid:sub(4, -4), 'in')
insert2(value, 'ft')
else
insert2(value, make_unit(tdata.wikidata_units, parms, uid) or uid)
end
return true
end
end
local function adjustparameters(tdata, parms, index)
-- For Module:Convert, adjust parms (a table of {{convert}} parameters).
-- Return true if successful or return false, t where t is an error message table.
-- This is intended mainly for use in infoboxes where the input might be
-- <value><space><unit> or
-- <wikidata-property-id>
-- If successful, insert values and units in parms, before given index.
local text = parms.input -- should be a trimmed, non-empty string
local pid = text:match('^P%d+$')
local sep = ','
local special = specials[parms[index]]
if special then
parms.out_unit = special[1]
sep = special[2] or sep
table.remove(parms, index)
end
local function quit()
return false, pid and { 'cvt_no_output' } or { 'cvt_bad_input', text }
end
local function insert2(first, second)
table.insert(parms, index, second)
table.insert(parms, index, first)
end
if pid then
parms.input_text = '' -- output an empty string if an error occurs
local result = input_from_property(tdata, parms, pid)
if result.n == 0 then
return quit()
end
local ucode
for i, t in ipairs(result) do
-- Convert requires each input unit to be identical.
if i == 1 then
ucode = t[2]
elseif ucode ~= t[2] then
return quit()
end
end
local item = ucode
if item == parms[index] then
-- Remove specified output unit if it is the same as the Wikidata unit.
-- For example, {{convert|input=P2044|km}} with property "12 km".
table.remove(parms, index)
end
for i = result.n, 1, -1 do
insert2(result[i][1], item)
item = sep
end
return true
else
if input_from_text(tdata, parms, text, insert2) then
return true
end
end
return quit()
end
--------------------------------------------------------------------------------
--- List units and check syntax of definitions ---------------------------------
--------------------------------------------------------------------------------
local specifications = {
-- seq = sequence in which fields are displayed
base = {
title = 'SI base units',
fields = {
symbol = { seq = 2, mandatory = true },
name1 = { seq = 3, mandatory = true },
name2 = { seq = 4 },
link = { seq = 5 },
},
noteseq = 6,
header = '{| class="wikitable"\n!si !!symbol !!name1 !!name2 !!link !!note',
item = '|-\n|%s ||%s ||%s ||%s ||%s ||%s',
footer = '|}',
},
alias = {
title = 'Aliases for convert',
fields = {
ucode = { seq = 2, mandatory = true },
si = { seq = 3 },
},
noteseq = 4,
header = '{| class="wikitable"\n!alias !!ucode !!base !!note',
item = '|-\n|%s ||%s ||%s ||%s',
footer = '|}',
},
known = {
title = 'Units known to convert',
fields = {
ucode = { seq = 2, mandatory = true },
label = { seq = 3, mandatory = true },
},
noteseq = 4,
header = '{| class="wikitable"\n!qid !!ucode !!label !!note',
item = '|-\n|%s ||%s ||%s ||%s',
footer = '|}',
},
unknown = {
title = 'Units not known to convert',
fields = {
_ucode = { seq = 2, mandatory = true },
si = { seq = 3 },
name1 = { seq = 4 },
name2 = { seq = 5 },
link = { seq = 6 },
label = { seq = 7, mandatory = true },
},
noteseq = 8,
header = '{| class="wikitable"\n!qid !!_ucode !!base !!name1 !!name2 !!link !!label !!note',
item = '|-\n|%s ||%s ||%s ||%s ||%s ||%s ||%s ||%s',
footer = '|}',
},
}
local function listunits(tdata, ulookup)
-- For Module:Convert, make wikitext to list the built-in Wikidata units.
-- Return true, wikitext if successful or return false, t where t is an
-- error message table. Currently, an error return never occurs.
-- The syntax of each unit definition is checked and a note is added if
-- a problem is detected.
local function safe_cells(t)
-- This is not currently needed, but in case definitions ever use wikitext
-- like '[[kilogram|kg]]', escape the text so it works in a table cell.
local result = {}
for i, v in ipairs(t) do
if v:find('|', 1, true) then
v = v:gsub('(%[%[[^%[%]]-)|(.-%]%])', '%1\0%2') -- replace pipe in piped link with a zero byte
v = v:gsub('|', '|') -- escape '|'
v = v:gsub('%z', '|') -- restore pipe in piped link
end
result[i] = v:gsub('{', '{') -- escape '{'
end
return unpack(result)
end
local wdunits = tdata.wikidata_units
local speckeys = { 'base', 'alias', 'unknown', 'known' }
for _, sid in ipairs(speckeys) do
specifications[sid].units = Collection.new()
end
local keys = Collection.new()
for k, v in pairs(wdunits) do
keys:add(k)
end
table.sort(keys)
local note_count = 0
for _, key in ipairs(keys) do
local unit = wdunits[key]
local ktext, sid
if key:match('^Q%d+$') then
ktext = '[[d:' .. key .. '|' .. key .. ']]'
if unit.ucode then
sid = 'known'
else
sid = 'unknown'
end
elseif unit.ucode then
ktext = key
sid = 'alias'
else
ktext = key
sid = 'base'
end
local result = { ktext }
local spec = specifications[sid]
local fields = spec.fields
local note = Collection.new()
for k, v in pairs(unit) do
if fields[k] then
local seq = fields[k].seq
if result[seq] then
note:add('duplicate ' .. k) -- cannot happen since keys are unique
else
result[seq] = v
end
else
note:add('invalid ' .. k)
end
end
for k, v in pairs(fields) do
local value = result[v.seq]
if value then
if k == 'si' and not wdunits[value] then
note:add('need si ' .. value)
end
if k == 'label' then
local wdl = mw.wikibase.getLabel(key)
if wdl ~= value then
note:add('label changed to ' .. tostring(wdl))
end
end
else
result[v.seq] = ''
if v.mandatory then
note:add('missing ' .. k)
end
end
end
local text
if note.n > 0 then
note_count = note_count + 1
text = '*' .. note:join('<br />')
end
result[spec.noteseq] = text or ''
spec.units:add(result)
end
local results = Collection.new()
if note_count > 0 then
local text = note_count .. (note_count == 1 and ' note' or ' notes')
results:add("'''Search for * to see " .. text .. "'''\n")
end
for _, sid in ipairs(speckeys) do
local spec = specifications[sid]
results:add("'''" .. spec.title .. "'''")
results:add(spec.header)
local fmt = spec.item
for _, unit in ipairs(spec.units) do
results:add(string.format(fmt, safe_cells(unit)))
end
results:add(spec.footer)
end
return true, results:join('\n')
end
return { _adjustparameters = adjustparameters, _listunits = listunits }
b93954acaa7b2c734c1c6f4c869ed6d1821a2d84
Module:Convert/wikidata/data
828
724
1112
1111
2025-08-22T00:55:51Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
--[[ Cache of Wikidata information with units for Module:Convert.
The codes should rarely change, and using a cache means that changing a
unit at Wikidata will not cause lots of converts in articles to break.
For a unit known to convert, the unit here must have:
label = Wikidata label for unit (used only when listing units)
ucode = unit code for input to convert
(there are no optional fields because convert handles everything)
For a unit not known to convert, the unit here must have:
label = Wikidata label for unit (used only when listing units)
(no ucode field)
_ucode = unit code for input to convert, and the
symbol used to display the unit when abbr=on
(convert will use the specified fields to display the unit,
and will not attempt to do a conversion)
For a unit not known to convert, the unit here may have:
name1 = singular name used to display the unit when abbr=off
name2 = plural name used to display the unit when abbr=off
link = name of article that unit will be linked to when lk=on
si = key for the SI base unit, if any
The base unit for each SI unit here must have:
symbol = symbol used to display the base unit when abbr=on
name1 = singular name of base unit used to display the unit when abbr=off
(if name1 is not given, symbol will be used, but an SI unit should have a name)
The base unit for each SI unit here may have:
name2 = plural name of base unit used to display the unit when abbr=off
link = name of article that unit will be linked to when lk=on
(applies for all SI units using this base, where the
SI unit does not define its own link field)
If name1 is not specified, the symbol is used for the name.
If name2 is not specified, a plural name is formed by appending 's' to name1.
If link is not specified, name1 is used for the link.
SI units are assumed to be simple items like V (volt) where 'mV' would
cause convert to insert:
'm' before the base symbol 'V' to make 'mV', if abbr=on
'milli' before the base name 'volt' to make 'millivolt', if abbr=off
A unit like "square meter" would not work because it needs an SI prefix
inserted before "meter" rather than at the beginning of the name.
Items that should not be used with convert as no precise unit is implied:
Q11247037 ton generic (cannot use)
Q178413 gallon generic
Q130964 calorie dubious (ambiguous, should not use)
Q216658 bushel dubious
Q420266 fluid ounce dubious
]]
local wikidata_units = {
-- Following are SI base units.
A = {
symbol = 'A',
name1 = 'ampere',
},
F = {
symbol = 'F',
name1 = 'faraday',
},
H = {
symbol = 'H',
name1 = 'henry',
},
V = {
symbol = 'V',
name1 = 'volt',
},
-- Following are aliases to convert unit codes, used with "input=<value><space><unit>".
kilograms = {
ucode = 'kg',
},
-- Following are SI units not known to convert, used with "input=<value><space><unit>".
kV = {
ucode = 'kV',
si = 'V',
},
mV = {
ucode = 'mV',
si = 'V',
},
-- Following are Wikidata units.
Q131255 = {
label = 'farad',
_ucode = 'F',
si = 'F',
},
Q163354 = {
label = 'henry',
_ucode = 'H',
si = 'H',
},
Q1916026 = {
label = 'microvolt',
_ucode = 'uV',
si = 'V',
},
Q193933 = {
label = 'dioptre',
name1 = 'dioptre',
_ucode = 'dpt',
},
Q212120 = {
label = 'ampere hour',
name1 = 'ampere hour',
_ucode = 'A⋅h',
},
Q2448803 = {
label = 'millivolt',
_ucode = 'mV',
si = 'V',
},
Q2451296 = {
label = 'microfarad',
_ucode = 'uF',
si = 'F',
},
Q2490574 = {
label = 'milliampere',
_ucode = 'mA',
si = 'A',
},
Q25250 = {
label = 'volt',
_ucode = 'V',
si = 'V',
},
Q25272 = {
label = 'ampere',
_ucode = 'A',
si = 'A',
},
Q2553708 = {
label = 'megavolt',
_ucode = 'MV',
si = 'V',
},
Q2554092 = {
label = 'kilovolt',
_ucode = 'kV',
si = 'V',
},
Q2636421 = {
label = 'nanohenry',
_ucode = 'nH',
si = 'H',
},
Q2679083 = {
label = 'microhenry',
_ucode = 'uH',
si = 'H',
},
Q2682463 = {
label = 'nanofarad',
_ucode = 'nF',
si = 'F',
},
Q2756030 = {
label = 'picofarad',
_ucode = 'pF',
si = 'F',
},
Q2793566 = {
label = 'gigavolt',
_ucode = 'GV',
si = 'V',
},
Q2924137 = {
label = 'millihenry',
_ucode = 'mH',
si = 'H',
},
Q3117809 = {
label = 'microampere',
_ucode = 'uA',
si = 'A',
},
Q33680 = {
label = 'radian',
name1 = 'radian',
_ucode = 'rad',
},
Q4456994 = {
label = 'millifarad',
_ucode = 'mF',
si = 'F',
},
Q47083 = {
label = 'ohm',
name1 = 'ohm',
_ucode = 'Ω',
},
Q483261 = {
label = 'dalton',
name1 = 'dalton',
_ucode = 'u',
},
Q550341 = {
label = 'volt-ampere',
name1 = 'volt-ampere',
_ucode = 'VA',
},
Q100995 = {
label = 'pound',
ucode = 'lb',
},
Q1022113 = {
label = 'cubic centimetre',
ucode = 'cc',
},
Q102573 = {
label = 'becquerel',
ucode = 'Bq',
},
Q103246 = {
label = 'sievert',
ucode = 'Sv',
},
Q1050958 = {
label = 'inch of mercury',
ucode = 'inHg',
},
Q1051665 = {
label = 'metre per second squared',
ucode = 'm/s2',
},
Q1052397 = {
label = 'rad',
ucode = 'rad',
},
Q1054140 = {
label = 'megametre',
ucode = 'Mm',
},
Q1057069 = {
label = 'hectogram',
ucode = 'hg',
},
Q1063786 = {
label = 'square inch',
ucode = 'sqin',
},
Q1092296 = {
label = 'annum',
ucode = 'year',
},
Q11570 = {
label = 'kilogram',
ucode = 'kg',
},
Q11573 = {
label = 'metre',
ucode = 'm',
},
Q11574 = {
label = 'second',
ucode = 's',
},
Q11579 = {
label = 'kelvin',
ucode = 'K',
},
Q11582 = {
label = 'litre',
ucode = 'litre',
},
Q1165588 = {
label = 'rod',
ucode = 'rod',
},
Q1165799 = {
label = 'thou',
ucode = 'thou',
},
Q11776930 = {
label = 'megagram',
ucode = 'Mg',
},
Q11929860 = {
label = 'kiloparsec',
ucode = 'kpc',
},
Q1194225 = {
label = 'pound-force',
ucode = 'lbf',
},
Q12129 = {
label = 'parsec',
ucode = 'pc',
},
Q12438 = {
label = 'newton',
ucode = 'N',
},
Q1255620 = {
label = 'dram',
ucode = 'drachm',
},
Q12874593 = {
label = 'watt-hour',
ucode = 'W.h',
},
Q128822 = {
label = 'knot',
ucode = 'kn',
},
Q1374438 = {
label = 'kilosecond',
ucode = 'ks',
},
Q1377051 = {
label = 'gigasecond',
ucode = 'Gs',
},
Q14754979 = {
label = 'zettagram',
ucode = 'Zg',
},
Q14786969 = {
label = 'megajoule',
ucode = 'MJ',
},
Q14787261 = {
label = 'megawatt hour',
ucode = 'MW.h',
},
Q1550511 = {
label = 'square yard',
ucode = 'sqyd',
},
Q160857 = {
label = 'metric horsepower',
ucode = 'hp',
},
Q1628990 = {
label = 'horsepower-hour',
ucode = 'hph',
},
Q163343 = {
label = 'tesla',
ucode = 'T',
},
Q1645498 = {
label = 'microgram',
ucode = 'ug',
},
Q17087835 = {
label = 'cuerda',
ucode = 'cda',
},
Q174728 = {
label = 'centimetre',
ucode = 'cm',
},
Q174789 = {
label = 'millimetre',
ucode = 'mm',
},
Q175821 = {
label = 'micrometre',
ucode = 'um',
},
Q1770733 = {
label = 'teragram',
ucode = 'Tg',
},
Q1772386 = {
label = 'decigram',
ucode = 'dg',
},
Q177493 = {
label = 'gauss',
ucode = 'G',
},
Q1777507 = {
label = 'femtosecond',
ucode = 'fs',
},
Q177974 = {
label = 'standard atmosphere',
ucode = 'atm',
},
Q178674 = {
label = 'nanometre',
ucode = 'nm',
},
Q180154 = {
label = 'kilometre per hour',
ucode = 'km/h',
},
Q180892 = {
label = 'solar mass',
ucode = 'solar mass',
},
Q1811 = {
label = 'astronomical unit',
ucode = 'au',
},
Q1815100 = {
label = 'centilitre',
ucode = 'cl',
},
Q182098 = {
label = 'kilowatt hour',
ucode = 'kW.h',
},
Q1823150 = {
label = 'microwatt',
ucode = 'uW',
},
Q182429 = {
label = 'metre per second',
ucode = 'm/s',
},
Q1826195 = {
label = 'decilitre',
ucode = 'dl',
},
Q185078 = {
label = 'are',
ucode = 'a',
},
Q185153 = {
label = 'erg',
ucode = 'erg',
},
Q185648 = {
label = 'torr',
ucode = 'Torr',
},
Q190095 = {
label = 'gray',
ucode = 'Gy',
},
Q191118 = {
label = 'tonne',
ucode = 'tonne',
},
Q1913097 = {
label = 'femtogram',
ucode = 'fg',
},
Q192274 = {
label = 'picometre',
ucode = 'pm',
},
Q1972579 = {
label = 'poundal',
ucode = 'pdl',
},
Q200323 = {
label = 'decimetre',
ucode = 'dm',
},
Q201933 = {
label = 'dyne',
ucode = 'dyn',
},
Q2029519 = {
label = 'hectolitre',
ucode = 'hl',
},
Q2051195 = {
label = 'gigawatt hour',
ucode = 'GW.h',
},
Q207488 = {
label = 'Rankine scale',
ucode = 'R',
},
Q208788 = {
label = 'femtometre',
ucode = 'fm',
},
Q2101 = {
label = 'elementary charge',
ucode = 'e',
},
Q21014455 = {
label = 'metre per minute',
ucode = 'm/min',
},
Q21062777 = {
label = 'megapascal',
ucode = 'MPa',
},
Q21064807 = {
label = 'kilopascal',
ucode = 'kPa',
},
Q211256 = {
label = 'mile per hour',
ucode = 'mph',
},
Q21178489 = {
label = 'barrels per day',
ucode = 'oilbbl/d',
},
Q2143992 = {
label = 'kilohertz',
ucode = 'kHz',
},
Q21467992 = {
label = 'cubic foot per second',
ucode = 'cuft/s',
},
Q215571 = {
label = 'newton metre',
ucode = 'Nm',
},
Q216795 = {
label = 'dunam',
ucode = 'dunam',
},
Q216880 = {
label = 'kilogram-force',
ucode = 'kgf',
},
Q18413919 = {
label = 'centimetre per second',
ucode = 'cm/s',
},
Q218593 = {
label = 'inch',
ucode = 'in',
},
Q2282891 = {
label = 'microlitre',
ucode = 'ul',
},
Q2282906 = {
label = 'nanogram',
ucode = 'ng',
},
Q229354 = {
label = 'curie',
ucode = 'Ci',
},
Q232291 = {
label = 'square mile',
ucode = 'sqmi',
},
Q2332346 = {
label = 'millilitre',
ucode = 'ml',
},
Q23387 = {
label = 'week',
ucode = 'week',
},
Q23823681 = {
label = 'terawatt',
ucode = 'TW',
},
Q23925410 = {
label = 'gallon (UK)',
ucode = 'impgal',
},
Q23925413 = {
label = 'gallon (US)',
ucode = 'USgal',
},
Q2438073 = {
label = 'attogram',
ucode = 'ag',
},
Q2474258 = {
label = 'millisievert',
ucode = 'mSv',
},
Q2483628 = {
label = 'attosecond',
ucode = 'as',
},
Q2489298 = {
label = 'square centimetre',
ucode = 'cm2',
},
Q2518569 = {
label = 'nanosievert',
ucode = 'nSv',
},
Q25235 = {
label = 'hour',
ucode = 'h',
},
Q25236 = {
label = 'watt',
ucode = 'W',
},
Q25267 = {
label = 'degree Celsius',
ucode = 'C',
},
Q25269 = {
label = 'joule',
ucode = 'J',
},
Q253276 = {
label = 'mile',
ucode = 'mi',
},
Q25343 = {
label = 'square metre',
ucode = 'm2',
},
Q25406 = {
label = 'coulomb',
ucode = 'coulomb',
},
Q25517 = {
label = 'cubic metre',
ucode = 'm3',
},
Q260126 = {
label = 'Roentgen equivalent man',
ucode = 'rem',
},
Q2612219 = {
label = 'petagram',
ucode = 'Pg',
},
Q2619500 = {
label = 'foe',
ucode = 'foe',
},
Q2637946 = {
label = 'decalitre',
ucode = 'dal',
},
Q2655272 = {
label = 'exagram',
ucode = 'Eg',
},
Q2691798 = {
label = 'centigram',
ucode = 'cg',
},
Q2739114 = {
label = 'microsievert',
ucode = 'uSv',
},
Q2799294 = {
label = 'gigagram',
ucode = 'Gg',
},
Q3013059 = {
label = 'kiloannum',
ucode = 'millennium',
},
Q305896 = {
label = 'dots per inch',
ucode = 'dpi',
},
Q3207456 = {
label = 'milliwatt',
ucode = 'mW',
},
Q3221356 = {
label = 'yoctometre',
ucode = 'ym',
},
Q3239557 = {
label = 'picogram',
ucode = 'pg',
},
Q3241121 = {
label = 'milligram',
ucode = 'mg',
},
Q3267417 = {
label = 'terametre',
ucode = 'Tm',
},
Q3270676 = {
label = 'zeptometre',
ucode = 'zm',
},
Q3276763 = {
label = 'gigahertz',
ucode = 'GHz',
},
Q3277907 = {
label = 'exametre',
ucode = 'Em',
},
Q3277915 = {
label = 'zettametre',
ucode = 'Zm',
},
Q3277919 = {
label = 'petametre',
ucode = 'Pm',
},
Q3312063 = {
label = 'femtolitre',
ucode = 'fl',
},
Q3320608 = {
label = 'kilowatt',
ucode = 'kW',
},
Q3332822 = {
label = 'megaton of TNT',
ucode = 'Mt(TNT)',
},
Q35852 = {
label = 'hectare',
ucode = 'ha',
},
Q3675550 = {
label = 'cubic millimetre',
ucode = 'mm3',
},
Q3710 = {
label = 'foot',
ucode = 'ft',
},
Q3773454 = {
label = 'megaparsec',
ucode = 'Mpc',
},
Q3902688 = {
label = 'picolitre',
ucode = 'pl',
},
Q3902709 = {
label = 'picosecond',
ucode = 'ps',
},
Q39369 = {
label = 'hertz',
ucode = 'Hz',
},
Q3972226 = {
label = 'kilolitre',
ucode = 'kl',
},
Q4068266 = {
label = "apothecaries' drachm",
ucode = 'drachm',
},
Q41803 = {
label = 'gram',
ucode = 'g',
},
Q4220561 = {
label = 'kilometre per second',
ucode = 'km/s',
},
Q42289 = {
label = 'degree Fahrenheit',
ucode = 'F',
},
Q4243638 = {
label = 'cubic kilometre',
ucode = 'km3',
},
Q44395 = {
label = 'pascal',
ucode = 'Pa',
},
Q48013 = {
label = 'ounce',
ucode = 'oz',
},
Q482798 = {
label = 'yard',
ucode = 'yd',
},
Q4989854 = {
label = 'kilojoule',
ucode = 'kJ',
},
Q4992853 = {
label = 'kiloton of TNT',
ucode = 'kt(TNT)',
},
Q5139563 = {
label = 'hectopascal',
ucode = 'hPa',
},
Q5151 = {
label = 'month',
ucode = 'month',
},
Q531 = {
label = 'light-year',
ucode = 'ly',
},
Q5465723 = {
label = 'foot-poundal',
ucode = 'ftpdl',
},
Q573 = {
label = 'day',
ucode = 'd',
},
Q577 = {
label = 'year',
ucode = 'year',
},
Q5879479 = {
label = 'gigawatt',
ucode = 'GW',
},
Q6003257 = {
label = 'attometre',
ucode = 'am',
},
Q613726 = {
label = 'yottagram',
ucode = 'Yg',
},
Q6170164 = {
label = 'yoctogram',
ucode = 'yg',
},
Q667419 = {
label = 'long ton',
ucode = 'LT',
},
Q673166 = {
label = 'gravity of Earth',
ucode = 'g0',
},
Q693944 = {
label = 'grain',
ucode = 'gr',
},
Q6982035 = {
label = 'megawatt',
ucode = 'MW',
},
Q712226 = {
label = 'square kilometre',
ucode = 'km2',
},
Q723733 = {
label = 'millisecond',
ucode = 'ms',
},
Q732454 = {
label = 'megaannum',
ucode = 'Myr',
},
Q732707 = {
label = 'megahertz',
ucode = 'MHz',
},
Q752079 = {
label = 'gross register ton',
ucode = 'grt',
},
Q752197 = {
label = 'kilojoule per mole',
ucode = 'kJ/mol',
},
Q7727 = {
label = 'minute',
ucode = 'min',
},
Q794261 = {
label = 'cubic metre per second',
ucode = 'm3/s',
},
Q809678 = {
label = 'barye',
ucode = 'Ba',
},
Q81292 = {
label = 'acre',
ucode = 'acre',
},
Q81454 = {
label = 'ångström',
ucode = 'angstrom',
},
Q828224 = {
label = 'kilometre',
ucode = 'km',
},
Q83327 = {
label = 'electronvolt',
ucode = 'eV',
},
Q838801 = {
label = 'nanosecond',
ucode = 'ns',
},
Q842015 = {
label = 'microsecond',
ucode = 'us',
},
Q844211 = {
label = 'kilogram per cubic metre',
ucode = 'kg/m3',
},
Q844338 = {
label = 'hectometre',
ucode = 'hm',
},
Q844976 = {
label = 'oersted',
ucode = 'Oe',
},
Q848856 = {
label = 'decametre',
ucode = 'dam',
},
Q854546 = {
label = 'gigametre',
ucode = 'Gm',
},
Q857027 = {
label = 'square foot',
ucode = 'sqft',
},
Q9048643 = {
label = 'nanolitre',
ucode = 'nl',
},
Q93318 = {
label = 'nautical mile',
ucode = 'nmi',
},
}
return { wikidata_units = wikidata_units }
780312bf04e64ca1dd5fb2b59dc26b420a30ab56
Module:Convert/extra
828
725
1114
1113
2025-08-22T00:55:52Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Extra conversion data used by Module:Convert.
--
-- [[Module:Convert/data]] defines all units and is transcluded in all pages
-- where [[Module:Convert]] is used. Testing new units by editing that module
-- would invalidate the cache for all affected pages.
--
-- For quick changes and experiments with new units, this module can be edited.
-- Since this module is transcluded in only a small number of pages, changes
-- should cause little server overhead and should propagate quickly.
--
-- If a unit is defined in the data module, any definition here is ignored,
-- so defining the same unit in both modules is not an error.
-- A unit defined here can refer to units that are also defined here, and
-- can refer to units defined in the data module.
--
-- Periodically, those extra units that are wanted permanently can be removed
-- from here after being added to [[Module:Convert/data]].
local extra_units = {
["bit"] = {
_name1 = "bit",
_symbol = "bit",
utype = "information",
scale = 0.125,
prefixes = 1,
default = "B",
link = "Bit",
},
["per-km2"] = {
name1 = "per square kilometre",
name1_us = "per square kilometer",
name2 = "per square kilometre",
name2_us = "per square kilometer",
symbol = "per km<sup>2</sup>",
utype = "per unit area",
scale = 1e-6,
default = "/sqmi",
link = "Square kilometre",
},
}
return { extra_units = extra_units }
55a4ac716545a8687a16e661345c64dca7597848
Module:ConvertNumeric
828
726
1116
1115
2025-08-22T00:55:52Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- Module for converting between different representations of numbers. See talk page for user documentation.
-- For unit tests see: [[Module:ConvertNumeric/testcases]]
-- When editing, preview with: [[Module_talk:ConvertNumeric/testcases]]
-- First, edit [[Module:ConvertNumeric/sandbox]], then preview with [[Module_talk:ConvertNumeric/sandbox/testcases]]
require('strict')
local ones_position = {
[0] = 'zero',
[1] = 'one',
[2] = 'two',
[3] = 'three',
[4] = 'four',
[5] = 'five',
[6] = 'six',
[7] = 'seven',
[8] = 'eight',
[9] = 'nine',
[10] = 'ten',
[11] = 'eleven',
[12] = 'twelve',
[13] = 'thirteen',
[14] = 'fourteen',
[15] = 'fifteen',
[16] = 'sixteen',
[17] = 'seventeen',
[18] = 'eighteen',
[19] = 'nineteen'
}
local ones_position_ord = {
[0] = 'zeroth',
[1] = 'first',
[2] = 'second',
[3] = 'third',
[4] = 'fourth',
[5] = 'fifth',
[6] = 'sixth',
[7] = 'seventh',
[8] = 'eighth',
[9] = 'ninth',
[10] = 'tenth',
[11] = 'eleventh',
[12] = 'twelfth',
[13] = 'thirteenth',
[14] = 'fourteenth',
[15] = 'fifteenth',
[16] = 'sixteenth',
[17] = 'seventeenth',
[18] = 'eighteenth',
[19] = 'nineteenth'
}
local ones_position_plural = {
[0] = 'zeros',
[1] = 'ones',
[2] = 'twos',
[3] = 'threes',
[4] = 'fours',
[5] = 'fives',
[6] = 'sixes',
[7] = 'sevens',
[8] = 'eights',
[9] = 'nines',
[10] = 'tens',
[11] = 'elevens',
[12] = 'twelves',
[13] = 'thirteens',
[14] = 'fourteens',
[15] = 'fifteens',
[16] = 'sixteens',
[17] = 'seventeens',
[18] = 'eighteens',
[19] = 'nineteens'
}
local tens_position = {
[2] = 'twenty',
[3] = 'thirty',
[4] = 'forty',
[5] = 'fifty',
[6] = 'sixty',
[7] = 'seventy',
[8] = 'eighty',
[9] = 'ninety'
}
local tens_position_ord = {
[2] = 'twentieth',
[3] = 'thirtieth',
[4] = 'fortieth',
[5] = 'fiftieth',
[6] = 'sixtieth',
[7] = 'seventieth',
[8] = 'eightieth',
[9] = 'ninetieth'
}
local tens_position_plural = {
[2] = 'twenties',
[3] = 'thirties',
[4] = 'forties',
[5] = 'fifties',
[6] = 'sixties',
[7] = 'seventies',
[8] = 'eighties',
[9] = 'nineties'
}
local groups = {
[1] = 'thousand',
[2] = 'million',
[3] = 'billion',
[4] = 'trillion',
[5] = 'quadrillion',
[6] = 'quintillion',
[7] = 'sextillion',
[8] = 'septillion',
[9] = 'octillion',
[10] = 'nonillion',
[11] = 'decillion',
[12] = 'undecillion',
[13] = 'duodecillion',
[14] = 'tredecillion',
[15] = 'quattuordecillion',
[16] = 'quindecillion',
[17] = 'sexdecillion',
[18] = 'septendecillion',
[19] = 'octodecillion',
[20] = 'novemdecillion',
[21] = 'vigintillion',
[22] = 'unvigintillion',
[23] = 'duovigintillion',
[24] = 'tresvigintillion',
[25] = 'quattuorvigintillion',
[26] = 'quinquavigintillion',
[27] = 'sesvigintillion',
[28] = 'septemvigintillion',
[29] = 'octovigintillion',
[30] = 'novemvigintillion',
[31] = 'trigintillion',
[32] = 'untrigintillion',
[33] = 'duotrigintillion',
[34] = 'trestrigintillion',
[35] = 'quattuortrigintillion',
[36] = 'quinquatrigintillion',
[37] = 'sestrigintillion',
[38] = 'septentrigintillion',
[39] = 'octotrigintillion',
[40] = 'noventrigintillion',
[41] = 'quadragintillion',
[51] = 'quinquagintillion',
[61] = 'sexagintillion',
[71] = 'septuagintillion',
[81] = 'octogintillion',
[91] = 'nonagintillion',
[101] = 'centillion',
[102] = 'uncentillion',
[103] = 'duocentillion',
[104] = 'trescentillion',
[111] = 'decicentillion',
[112] = 'undecicentillion',
[121] = 'viginticentillion',
[122] = 'unviginticentillion',
[131] = 'trigintacentillion',
[141] = 'quadragintacentillion',
[151] = 'quinquagintacentillion',
[161] = 'sexagintacentillion',
[171] = 'septuagintacentillion',
[181] = 'octogintacentillion',
[191] = 'nonagintacentillion',
[201] = 'ducentillion',
[301] = 'trecentillion',
[401] = 'quadringentillion',
[501] = 'quingentillion',
[601] = 'sescentillion',
[701] = 'septingentillion',
[801] = 'octingentillion',
[901] = 'nongentillion',
[1001] = 'millinillion',
}
local roman_numerals = {
I = 1,
V = 5,
X = 10,
L = 50,
C = 100,
D = 500,
M = 1000
}
local engord_tens_end = {
['twentieth'] = 20,
['thirtieth'] = 30,
['fortieth'] = 40,
['fiftieth'] = 50,
['sixtieth'] = 60,
['seventieth'] = 70,
['eightieth'] = 80,
['ninetieth'] = 90,
}
local eng_tens_cont = {
['twenty'] = 20,
['thirty'] = 30,
['forty'] = 40,
['fifty'] = 50,
['sixty'] = 60,
['seventy'] = 70,
['eighty'] = 80,
['ninety'] = 90,
}
-- Converts a given valid roman numeral (and some invalid roman numerals) to a number. Returns { -1, errorstring } on error.
local function roman_to_numeral(roman)
if type(roman) ~= "string" then return -1, "roman numeral not a string" end
local rev = roman:reverse()
local raising = true
local last = 0
local result = 0
for i = 1, #rev do
local c = rev:sub(i, i)
local next = roman_numerals[c]
if next == nil then return -1, "roman numeral contains illegal character " .. c end
if next > last then
result = result + next
raising = true
elseif next < last then
result = result - next
raising = false
elseif raising then
result = result + next
else
result = result - next
end
last = next
end
return result
end
-- Converts a given integer between 0 and 100 to English text (e.g. 47 -> forty-seven).
local function numeral_to_english_less_100(num, ordinal, plural, zero)
local terminal_ones, terminal_tens
if ordinal then
terminal_ones = ones_position_ord
terminal_tens = tens_position_ord
elseif plural then
terminal_ones = ones_position_plural
terminal_tens = tens_position_plural
else
terminal_ones = ones_position
terminal_tens = tens_position
end
if num == 0 and zero ~= nil then
return zero
elseif num < 20 then
return terminal_ones[num]
elseif num % 10 == 0 then
return terminal_tens[num / 10]
else
return tens_position[math.floor(num / 10)] .. '-' .. terminal_ones[num % 10]
end
end
local function standard_suffix(ordinal, plural)
if ordinal then return 'th' end
if plural then return 's' end
return ''
end
-- Converts a given integer (in string form) between 0 and 1000 to English text (e.g. 47 -> forty-seven).
local function numeral_to_english_less_1000(num, use_and, ordinal, plural, zero)
num = tonumber(num)
if num < 100 then
return numeral_to_english_less_100(num, ordinal, plural, zero)
elseif num % 100 == 0 then
return ones_position[num/100] .. ' hundred' .. standard_suffix(ordinal, plural)
else
return ones_position[math.floor(num/100)] .. ' hundred ' .. (use_and and 'and ' or '') .. numeral_to_english_less_100(num % 100, ordinal, plural, zero)
end
end
-- Converts an ordinal in English text from 'zeroth' to 'ninety-ninth' inclusive to a number [0–99], else -1.
local function english_to_ordinal(english)
local eng = string.lower(english or '')
local engord_lt20 = {} -- ones_position_ord{} keys & values swapped
for k, v in pairs( ones_position_ord ) do
engord_lt20[v] = k
end
if engord_lt20[eng] then
return engord_lt20[eng] -- e.g. first -> 1
elseif engord_tens_end[eng] then
return engord_tens_end[eng] -- e.g. ninetieth -> 90
else
local tens, ones = string.match(eng, '^([a-z]+)[%s%-]+([a-z]+)$')
if tens and ones then
local tens_cont = eng_tens_cont[tens]
local ones_end = engord_lt20[ones]
if tens_cont and ones_end then
return tens_cont + ones_end -- e.g. ninety-ninth -> 99
end
end
end
return -1 -- Failed
end
-- Converts a number in English text from 'zero' to 'ninety-nine' inclusive to a number [0–99], else -1.
local function english_to_numeral(english)
local eng = string.lower(english or '')
local eng_lt20 = { ['single'] = 1 } -- ones_position{} keys & values swapped
for k, v in pairs( ones_position ) do
eng_lt20[v] = k
end
if eng_lt20[eng] then
return eng_lt20[eng] -- e.g. one -> 1
elseif eng_tens_cont[eng] then
return eng_tens_cont[eng] -- e.g. ninety -> 90
else
local tens, ones = string.match(eng, '^([a-z]+)[%s%-]+([a-z]+)$')
if tens and ones then
local tens_cont = eng_tens_cont[tens]
local ones_end = eng_lt20[ones]
if tens_cont and ones_end then
return tens_cont + ones_end -- e.g. ninety-nine -> 99
end
end
end
return -1 -- Failed
end
-- Converts a number expressed as a string in scientific notation to a string in standard decimal notation
-- e.g. 1.23E5 -> 123000, 1.23E-5 = .0000123. Conversion is exact, no rounding is performed.
local function scientific_notation_to_decimal(num)
local exponent, subs = num:gsub("^%-?%d*%.?%d*%-?[Ee]([+%-]?%d+)$", "%1")
if subs == 0 then return num end -- Input not in scientific notation, just return unmodified
exponent = tonumber(exponent)
local negative = num:find("^%-")
local _, decimal_pos = num:find("%.")
-- Mantissa will consist of all decimal digits with no decimal point
local mantissa = num:gsub("^%-?(%d*)%.?(%d*)%-?[Ee][+%-]?%d+$", "%1%2")
if negative and decimal_pos then decimal_pos = decimal_pos - 1 end
if not decimal_pos then decimal_pos = #mantissa + 1 end
-- Remove leading zeros unless decimal point is in first position
while decimal_pos > 1 and mantissa:sub(1,1) == '0' do
mantissa = mantissa:sub(2)
decimal_pos = decimal_pos - 1
end
-- Shift decimal point right for exponent > 0
while exponent > 0 do
decimal_pos = decimal_pos + 1
exponent = exponent - 1
if decimal_pos > #mantissa + 1 then mantissa = mantissa .. '0' end
-- Remove leading zeros unless decimal point is in first position
while decimal_pos > 1 and mantissa:sub(1,1) == '0' do
mantissa = mantissa:sub(2)
decimal_pos = decimal_pos - 1
end
end
-- Shift decimal point left for exponent < 0
while exponent < 0 do
if decimal_pos == 1 then
mantissa = '0' .. mantissa
else
decimal_pos = decimal_pos - 1
end
exponent = exponent + 1
end
-- Insert decimal point in correct position and return
return (negative and '-' or '') .. mantissa:sub(1, decimal_pos - 1) .. '.' .. mantissa:sub(decimal_pos)
end
-- Rounds a number to the nearest integer (NOT USED)
local function round_num(x)
if x%1 >= 0.5 then
return math.ceil(x)
else
return math.floor(x)
end
end
-- Rounds a number to the nearest two-word number (round = up, down, or "on" for round to nearest).
-- Numbers with two digits before the decimal will be rounded to an integer as specified by round.
-- Larger numbers will be rounded to a number with only one nonzero digit in front and all other digits zero.
-- Negative sign is preserved and does not count towards word limit.
local function round_for_english(num, round)
-- If an integer with at most two digits, just return
if num:find("^%-?%d?%d%.?$") then return num end
local negative = num:find("^%-")
if negative then
-- We're rounding magnitude so flip it
if round == 'up' then round = 'down' elseif round == 'down' then round = 'up' end
end
-- If at most two digits before decimal, round to integer and return
local _, _, small_int, trailing_digits, round_digit = num:find("^%-?(%d?%d?)%.((%d)%d*)$")
if small_int then
if small_int == '' then small_int = '0' end
if (round == 'up' and trailing_digits:find('[1-9]')) or (round == 'on' and tonumber(round_digit) >= 5) then
small_int = tostring(tonumber(small_int) + 1)
end
return (negative and '-' or '') .. small_int
end
-- When rounding up, any number with > 1 nonzero digit will round up (e.g. 1000000.001 rounds up to 2000000)
local nonzero_digits = 0
for digit in num:gfind("[1-9]") do
nonzero_digits = nonzero_digits + 1
end
num = num:gsub("%.%d*$", "") -- Remove decimal part
-- Second digit used to determine which way to round lead digit
local _, _, lead_digit, round_digit, round_digit_2, rest = num:find("^%-?(%d)(%d)(%d)(%d*)$")
if tonumber(lead_digit .. round_digit) < 20 and (1 + #rest) % 3 == 0 then
-- In English numbers < 20 are one word so put 2 digits in lead and round based on 3rd
lead_digit = lead_digit .. round_digit
round_digit = round_digit_2
else
rest = round_digit_2 .. rest
end
if (round == 'up' and nonzero_digits > 1) or (round == 'on' and tonumber(round_digit) >= 5) then
lead_digit = tostring(tonumber(lead_digit) + 1)
end
-- All digits but lead digit will turn to zero
rest = rest:gsub("%d", "0")
return (negative and '-' or '') .. lead_digit .. '0' .. rest
end
local denominators = {
[2] = { 'half', plural = 'halves' },
[3] = { 'third' },
[4] = { 'quarter', us = 'fourth' },
[5] = { 'fifth' },
[6] = { 'sixth' },
[8] = { 'eighth' },
[9] = { 'ninth' },
[10] = { 'tenth' },
[16] = { 'sixteenth' },
}
-- Return status, fraction where:
-- status is a string:
-- "finished" if there is a fraction with no whole number;
-- "ok" if fraction is empty or valid;
-- "unsupported" if bad fraction;
-- fraction is a string giving (numerator / denominator) as English text, or is "".
-- Only unsigned fractions with a very limited range of values are supported,
-- except that if whole is empty, the numerator can use "-" to indicate negative.
-- whole (string or nil): nil or "" if no number before the fraction
-- numerator (string or nil): numerator, if any (default = 1 if a denominator is given)
-- denominator (string or nil): denominator, if any
-- sp_us (boolean): true if sp=us
-- negative_word (string): word to use for negative sign, if whole is empty
-- use_one (boolean): false: 2+1/2 → "two and a half"; true: "two and one-half"
local function fraction_to_english(whole, numerator, denominator, sp_us, negative_word, use_one)
if numerator or denominator then
local finished = (whole == nil or whole == '')
local sign = ''
if numerator then
if finished and numerator:sub(1, 1) == '-' then
numerator = numerator:sub(2)
sign = negative_word .. ' '
end
else
numerator = '1'
end
if not numerator:match('^%d+$') or not denominator or not denominator:match('^%d+$') then
return 'unsupported', ''
end
numerator = tonumber(numerator)
denominator = tonumber(denominator)
local dendata = denominators[denominator]
if not (dendata and 1 <= numerator and numerator <= 99) then
return 'unsupported', ''
end
local numstr, denstr
local sep = '-'
if numerator == 1 then
denstr = sp_us and dendata.us or dendata[1]
if finished or use_one then
numstr = 'one'
elseif denstr:match('^[aeiou]') then
numstr = 'an'
sep = ' '
else
numstr = 'a'
sep = ' '
end
else
numstr = numeral_to_english_less_100(numerator)
denstr = dendata.plural
if not denstr then
denstr = (sp_us and dendata.us or dendata[1]) .. 's'
end
end
if finished then
return 'finished', sign .. numstr .. sep .. denstr
end
return 'ok', ' and ' .. numstr .. sep .. denstr
end
return 'ok', ''
end
-- Takes a decimal number and converts it to English text.
-- Return nil if a fraction cannot be converted (only some numbers are supported for fractions).
-- num (string or nil): the number to convert.
-- Can be an arbitrarily large decimal, such as "-123456789123456789.345", and
-- can use scientific notation (e.g. "1.23E5").
-- May fail for very large numbers not listed in "groups" such as "1E4000".
-- num is nil if there is no whole number before a fraction.
-- numerator (string or nil): numerator of fraction (nil if no fraction)
-- denominator (string or nil): denominator of fraction (nil if no fraction)
-- capitalize (boolean): whether to capitalize the result (e.g. 'One' instead of 'one')
-- use_and (boolean): whether to use the word 'and' between tens/ones place and higher places
-- hyphenate (boolean): whether to hyphenate all words in the result, useful as an adjective
-- ordinal (boolean): whether to produce an ordinal (e.g. 'first' instead of 'one')
-- plural (boolean): whether to pluralize the resulting number
-- links: nil: do not add any links; 'on': link "billion" and larger to Orders of magnitude article;
-- any other text: list of numbers to link (e.g. "billion,quadrillion")
-- negative_word: word to use for negative sign (typically 'negative' or 'minus'; nil to use default)
-- round: nil or '': no rounding; 'on': round to nearest two-word number; 'up'/'down': round up/down to two-word number
-- zero: word to use for value '0' (nil to use default)
-- use_one (boolean): false: 2+1/2 → "two and a half"; true: "two and one-half"
local function _numeral_to_english(num, numerator, denominator, capitalize, use_and, hyphenate, ordinal, plural, links, negative_word, round, zero, use_one)
if not negative_word then
if use_and then
-- TODO Should 'minus' be used when do not have sp=us?
-- If so, need to update testcases, and need to fix "minus zero".
-- negative_word = 'minus'
negative_word = 'negative'
else
negative_word = 'negative'
end
end
local status, fraction_text = fraction_to_english(num, numerator, denominator, not use_and, negative_word, use_one)
if status == 'unsupported' then
return nil
end
if status == 'finished' then
-- Input is a fraction with no whole number.
-- Hack to avoid executing stuff that depends on num being a number.
local s = fraction_text
if hyphenate then s = s:gsub("%s", "-") end
if capitalize then s = s:gsub("^%l", string.upper) end
return s
end
num = scientific_notation_to_decimal(num)
if round and round ~= '' then
if round ~= 'on' and round ~= 'up' and round ~= 'down' then
error("Invalid rounding mode")
end
num = round_for_english(num, round)
end
-- Separate into negative sign, num (digits before decimal), decimal_places (digits after decimal)
local MINUS = '−' -- Unicode U+2212 MINUS SIGN (may be in values from [[Module:Convert]])
if num:sub(1, #MINUS) == MINUS then
num = '-' .. num:sub(#MINUS + 1) -- replace MINUS with '-'
elseif num:sub(1, 1) == '+' then
num = num:sub(2) -- ignore any '+'
end
local negative = num:find("^%-")
local decimal_places, subs = num:gsub("^%-?%d*%.(%d+)$", "%1")
if subs == 0 then decimal_places = nil end
num, subs = num:gsub("^%-?(%d*)%.?%d*$", "%1")
if num == '' and decimal_places then num = '0' end
if subs == 0 or num == '' then error("Invalid decimal numeral") end
-- For each group of 3 digits except the last one, print with appropriate group name (e.g. million)
local s = ''
while #num > 3 do
if s ~= '' then s = s .. ' ' end
local group_num = math.floor((#num - 1) / 3)
local group = groups[group_num]
local group_digits = #num - group_num*3
s = s .. numeral_to_english_less_1000(num:sub(1, group_digits), false, false, false, zero) .. ' '
if links and (((links == 'on' and group_num >= 3) or links:find(group)) and group_num <= 13) then
s = s .. '[[Orders_of_magnitude_(numbers)#10' .. group_num*3 .. '|' .. group .. ']]'
else
s = s .. group
end
num = num:sub(1 + group_digits)
num = num:gsub("^0*", "") -- Trim leading zeros
end
-- Handle final three digits of integer part
if s ~= '' and num ~= '' then
if #num <= 2 and use_and then
s = s .. ' and '
else
s = s .. ' '
end
end
if s == '' or num ~= '' then
s = s .. numeral_to_english_less_1000(num, use_and, ordinal, plural, zero)
elseif ordinal or plural then
-- Round numbers like "one million" take standard suffixes for ordinal/plural
s = s .. standard_suffix(ordinal, plural)
end
-- For decimal places (if any) output "point" followed by spelling out digit by digit
if decimal_places then
s = s .. ' point'
for i = 1, #decimal_places do
s = s .. ' ' .. ones_position[tonumber(decimal_places:sub(i,i))]
end
end
s = s:gsub("^%s*(.-)%s*$", "%1") -- Trim whitespace
if ordinal and plural then s = s .. 's' end -- s suffix works for all ordinals
if negative and s ~= zero then s = negative_word .. ' ' .. s end
s = s:gsub("negative zero", "zero")
s = s .. fraction_text
if hyphenate then s = s:gsub("%s", "-") end
if capitalize then s = s:gsub("^%l", string.upper) end
return s
end
local function _numeral_to_english2(args)
local num = tostring(args.num)
num = num:gsub("^%s*(.-)%s*$", "%1") -- Trim whitespace
num = num:gsub(",", "") -- Remove commas
num = num:gsub("^<span[^<>]*></span>", "") -- Generated by Template:age
if num ~= '' then -- a fraction may have an empty whole number
if not num:find("^%-?%d*%.?%d*%-?[Ee]?[+%-]?%d*$") then
-- Input not in a valid format, try to eval it as an expr to see
-- if that produces a number (e.g. "3 + 5" will become "8").
local noerr, result = pcall(mw.ext.ParserFunctions.expr, num)
if noerr then
num = result
end
end
end
-- Call helper function passing args
return _numeral_to_english(
num,
args['numerator'],
args['denominator'],
args['capitalize'],
args['use_and'],
args['hyphenate'],
args['ordinal'],
args['plural'],
args['links'],
args['negative_word'],
args['round'],
args['zero'],
args['use_one']
) or ''
end
local p = { -- Functions that can be called from another module
roman_to_numeral = roman_to_numeral,
spell_number = _numeral_to_english,
spell_number2 = _numeral_to_english2,
english_to_ordinal = english_to_ordinal,
english_to_numeral = english_to_numeral,
}
function p._roman_to_numeral(frame) -- Callable via {{#invoke:ConvertNumeric|_roman_to_numeral|VI}}
return roman_to_numeral(frame.args[1])
end
function p._english_to_ordinal(frame) -- callable via {{#invoke:ConvertNumeric|_english_to_ordinal|First}}
return english_to_ordinal(frame.args[1])
end
function p._english_to_numeral(frame) -- callable via {{#invoke:ConvertNumeric|_english_to_numeral|One}}
return english_to_numeral(frame.args[1])
end
function p.numeral_to_english(frame)
local args = frame.args
-- Tail call to helper function passing args from frame
return _numeral_to_english2{
['num'] = args[1],
['numerator'] = args['numerator'],
['denominator'] = args['denominator'],
['capitalize'] = args['case'] == 'U' or args['case'] == 'u',
['use_and'] = args['sp'] ~= 'us',
['hyphenate'] = args['adj'] == 'on',
['ordinal'] = args['ord'] == 'on',
['plural'] = args['pl'] == 'on',
['links'] = args['lk'],
['negative_word'] = args['negative'],
['round'] = args['round'],
['zero'] = args['zero'],
['use_one'] = args['one'] == 'one' -- experiment: using '|one=one' makes fraction 2+1/2 give "two and one-half" instead of "two and a half"
}
end
---- recursive function for p.decToHex
local function decToHexDigit(dec)
local dig = {"0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"}
local div = math.floor(dec/16)
local mod = dec-(16*div)
if div >= 1 then return decToHexDigit(div)..dig[mod+1] else return dig[mod+1] end
end -- I think this is supposed to be done with a tail call but first I want something that works at all
---- finds all the decimal numbers in the input text and hexes each of them
function p.decToHex(frame)
local args=frame.args
local parent=frame.getParent(frame)
local pargs={}
if parent then pargs=parent.args end
local text=args[1] or pargs[1] or ""
local minlength=args.minlength or pargs.minlength or 1
minlength=tonumber(minlength)
local prowl=mw.ustring.gmatch(text,"(.-)(%d+)")
local output=""
repeat
local chaff,dec=prowl()
if not(dec) then break end
local hex=decToHexDigit(dec)
while (mw.ustring.len(hex)<minlength) do hex="0"..hex end
output=output..chaff..hex
until false
local chaff=mw.ustring.match(text,"(%D+)$") or ""
return output..chaff
end
return p
dbb876f8710ee1407b421a28b3e9bc5a6ea36cda
Template:Fraction
10
727
1118
1117
2025-08-22T00:55:52Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
<templatestyles src="Fraction/styles.css" /><!--
--><span class="frac"><!--
-->{{#if:{{{3|}}}<!-- if 3
-->|{{{1}}}<span class="sr-only">+</span><span class="num">{{{2}}}</span>⁄<span class="den">{{{3}}}</span><!-- then 1 2/3
-->|{{#if:{{{2|}}}<!-- elseif 2
-->|<span class="num">{{{1}}}</span>⁄<span class="den">{{{2}}}</span><!-- then 1/2
-->|{{#if:{{{1|}}}<!-- elseif 1
-->|<span class="num">1</span>⁄<span class="den">{{{1}}}</span><!-- then 1/1
-->|⁄<!-- else 0, a slash
-->}}<!-- endif 1
-->}}<!-- endif 2
-->}}<!-- endif 3
--></span><noinclude>
{{documentation}}
</noinclude>
92a487359898e00b80676732b41757019446ae53
Template:Fraction/styles.css
10
728
1120
1119
2025-08-22T00:55:52Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
/* {{pp|small=y}} */
.frac {
white-space: nowrap;
}
.frac .num,
.frac .den {
font-size: 80%;
line-height: 0; /* we want this inline */
vertical-align: super;
}
.frac .den {
vertical-align: sub;
}
/* [[Template:Screen reader-only]] is canonical implementation onwiki */
.sr-only {
border: 0;
clip: rect(0, 0, 0, 0);
clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
/* white-space: nowrap; /* already have nowrap above */
}
b28507c69a3866957f0cad2cbdb76d24154ba271
Template:Sfrac
10
729
1122
1121
2025-08-22T00:55:52Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{ {{{|safesubst:}}}#invoke:Unsubst||$B=<templatestyles src="Sfrac/styles.css" /><span class="sfrac">⁠{{#if:{{{3|}}}|{{{1}}}<span class="sr-only">+</span>}}<!--
--><span class="tion" {{#if:{{{font-size|}}}|style="font-size:{{{font-size}}}"}}><!--
--><span class="num">{{#if:{{{3|}}}|{{{2}}}|{{#if:{{{2|}}}|{{{1}}}|1}}}}</span><!--
--><span class="sr-only">/</span><!--
--><span class="den">{{{3|{{{2|{{{1|1}}}}}}}}}</span><!--
--></span><!--
-->⁠</span>}}<noinclude>
{{documentation}}
<!-- Add categories to /doc subpage, not here. -->
</noinclude>
1a4f22ed67a613ab0f1d9abf9816187efc00f50a
Module:Unsubst
828
730
1124
1123
2025-08-22T00:55:52Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
local checkType = require('libraryUtil').checkType
local p = {}
local BODY_PARAM = '$B'
local specialParams = {
['$params'] = 'parameter list',
['$aliases'] = 'parameter aliases',
['$flags'] = 'flags',
['$B'] = 'template content',
['$template-name'] = 'template invocation name override',
}
function p.main(frame, body)
-- If we are substing, this function returns a template invocation, and if
-- not, it returns the template body. The template body can be specified in
-- the body parameter, or in the template parameter defined in the
-- BODY_PARAM variable. This function can be called from Lua or from
-- #invoke.
-- Return the template body if we aren't substing.
if not mw.isSubsting() then
if body ~= nil then
return body
elseif frame.args[BODY_PARAM] ~= nil then
return frame.args[BODY_PARAM]
else
error(string.format(
"no template content specified (use parameter '%s' from #invoke)",
BODY_PARAM
), 2)
end
end
-- Sanity check for the frame object.
if type(frame) ~= 'table'
or type(frame.getParent) ~= 'function'
or not frame:getParent()
then
error(
"argument #1 to 'main' must be a frame object with a parent " ..
"frame available",
2
)
end
-- Find the invocation name.
local mTemplateInvocation = require('Module:Template invocation')
local name
if frame.args['$template-name'] and '' ~= frame.args['$template-name'] then
name = frame.args['$template-name'] -- override whatever the template name is with this name
else
name = mTemplateInvocation.name(frame:getParent():getTitle())
end
-- Combine passed args with passed defaults
local args = {}
if string.find( ','..(frame.args['$flags'] or '')..',', ',%s*override%s*,' ) then
for k, v in pairs( frame:getParent().args ) do
args[k] = v
end
for k, v in pairs( frame.args ) do
if not specialParams[k] then
if v == '__DATE__' then
v = mw.getContentLanguage():formatDate( 'F Y' )
end
args[k] = v
end
end
else
for k, v in pairs( frame.args ) do
if not specialParams[k] then
if v == '__DATE__' then
v = mw.getContentLanguage():formatDate( 'F Y' )
end
args[k] = v
end
end
for k, v in pairs( frame:getParent().args ) do
args[k] = v
end
end
-- Trim parameters, if not specified otherwise
if not string.find( ','..(frame.args['$flags'] or '')..',', ',%s*keep%-whitespace%s*,' ) then
for k, v in pairs( args ) do args[k] = mw.ustring.match(v, '^%s*(.*)%s*$') or '' end
end
-- Pull information from parameter aliases
local aliases = {}
if frame.args['$aliases'] then
local list = mw.text.split( frame.args['$aliases'], '%s*,%s*' )
for k, v in ipairs( list ) do
local tmp = mw.text.split( v, '%s*>%s*' )
aliases[tonumber(mw.ustring.match(tmp[1], '^[1-9][0-9]*$')) or tmp[1]] = ((tonumber(mw.ustring.match(tmp[2], '^[1-9][0-9]*$'))) or tmp[2])
end
end
for k, v in pairs( aliases ) do
if args[k] and ( not args[v] or args[v] == '' ) then
args[v] = args[k]
end
args[k] = nil
end
-- Remove empty parameters, if specified
if string.find( ','..(frame.args['$flags'] or '')..',', ',%s*remove%-empty%s*,' ) then
local tmp = 0
for k, v in ipairs( args ) do
if v ~= '' or ( args[k+1] and args[k+1] ~= '' ) or ( args[k+2] and args[k+2] ~= '' ) then
tmp = k
else
break
end
end
for k, v in pairs( args ) do
if v == '' then
if not (type(k) == 'number' and k < tmp) then args[k] = nil end
end
end
end
-- Order parameters
if frame.args['$params'] then
local params, tmp = mw.text.split( frame.args['$params'], '%s*,%s*' ), {}
for k, v in ipairs(params) do
v = tonumber(mw.ustring.match(v, '^[1-9][0-9]*$')) or v
if args[v] then tmp[v], args[v] = args[v], nil end
end
for k, v in pairs(args) do tmp[k], args[k] = args[k], nil end
args = tmp
end
return mTemplateInvocation.invocation(name, args)
end
p[''] = p.main -- For backwards compatibility
return p
7f01ffc8aa2ac4a4772f14c12e0b77e384ecabb6
Module:Template invocation
828
731
1126
1125
2025-08-22T00:55:53Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
-- This module provides functions for making MediaWiki template invocations.
local checkType = require('libraryUtil').checkType
local p = {}
------------------------------------------------------------------------
-- Name: p.name
-- Purpose: Find a template invocation name from a page name or a
-- mw.title object.
-- Description: This function detects whether a string or a mw.title
-- object has been passed in, and uses that to find a
-- template name as it is used in template invocations.
-- Parameters: title - full page name or mw.title object for the
-- template (string or mw.title object)
-- Returns: String
------------------------------------------------------------------------
function p.name(title)
if type(title) == 'string' then
title = mw.title.new(title)
if not title or #title.prefixedText == 0 or #title.interwiki > 0 then
error("invalid title in parameter #1 of function 'name'", 2)
end
elseif type(title) ~= 'table' or type(title.getContent) ~= 'function' then
error("parameter #1 of function 'name' must be a string or a mw.title object", 2)
end
if title.namespace == 10 then
local text = title.text
local check = mw.title.new(text, 10)
-- Exclude the prefix, unless we have something like "Template:Category:Foo", which can't be abbreviated to "Category:Foo".
return check and mw.title.equals(title, check) and text or title.prefixedText
elseif title.namespace == 0 then
return ':' .. title.prefixedText
else
return title.prefixedText
end
end
------------------------------------------------------------------------
-- Name: p.invocation
-- Purpose: Construct a MediaWiki template invocation.
-- Description: This function makes a template invocation from the
-- name and the arguments given. Note that it isn't
-- perfect: we have no way of knowing what whitespace was
-- in the original invocation, the named parameters will be
-- alphabetically sorted, and any parameters with duplicate keys
-- will be removed.
-- Parameters: name - the template name, formatted as it will appear
-- in the invocation. (string)
-- args - a table of template arguments. (table)
-- format - formatting options. (string, optional)
-- Set to "nowiki" to escape, curly braces, pipes and
-- equals signs with their HTML entities. The default
-- is unescaped.
-- Returns: String
------------------------------------------------------------------------
function p.invocation(name, args, format)
checkType('invocation', 1, name, 'string')
checkType('invocation', 2, args, 'table')
checkType('invocation', 3, format, 'string', true)
-- Validate the args table and make a copy to work from. We need to
-- make a copy of the table rather than just using the original, as
-- some of the values may be erased when building the invocation.
local invArgs = {}
for k, v in pairs(args) do
local typek = type(k)
local typev = type(v)
if typek ~= 'string' and typek ~= 'number'
or typev ~= 'string' and typev ~= 'number'
then
error("invalid arguments table in parameter #2 of " ..
"'invocation' (keys and values must be strings or numbers)", 2)
end
invArgs[k] = v
end
-- Get the separators to use.
local seps = {
openb = '{{',
closeb = '}}',
pipe = '|',
equals = '='
}
if format == 'nowiki' then
for k, v in pairs(seps) do
seps[k] = mw.text.nowiki(v)
end
end
-- Build the invocation body with numbered args first, then named.
local ret = {}
ret[#ret + 1] = seps.openb
ret[#ret + 1] = name
for k, v in ipairs(invArgs) do
if type(v) == 'string' and v:find('=', 1, true) then
-- Likely something like 1=foo=bar which needs to be displayed as a named arg.
else
ret[#ret + 1] = seps.pipe
ret[#ret + 1] = v
invArgs[k] = nil -- Erase the key so that we don't add the value twice
end
end
local keys = {} -- sort parameter list; better than arbitrary order
for k, _ in pairs(invArgs) do
keys[#keys + 1] = k
end
table.sort(keys,
function (a, b)
-- Sort with keys of type number first, then string.
if type(a) == type(b) then
return a < b
elseif type(a) == 'number' then
return true
end
end
)
local maybeSpace = '' -- First named parameter should not be separated by a space
for _, v in ipairs(keys) do -- Add named args based on sorted parameter list
ret[#ret + 1] = maybeSpace .. seps.pipe
ret[#ret + 1] = tostring(v)
ret[#ret + 1] = seps.equals
ret[#ret + 1] = invArgs[v]
maybeSpace = ' '
end
ret[#ret + 1] = seps.closeb
return table.concat(ret)
end
return p
1670c64056477574789c5c21349ec2234f60dd9c
Template:Sfrac/styles.css
10
732
1128
1127
2025-08-22T00:55:53Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
/* {{pp|small=y}} */
.sfrac {
white-space: nowrap;
}
.sfrac.tion,
.sfrac .tion {
display: inline-block;
vertical-align: -0.5em;
font-size: 85%;
text-align: center;
}
.sfrac .num {
display: block;
line-height: 1em;
margin: 0.0em 0.1em;
border-bottom: 1px solid;
}
.sfrac .den {
display: block;
line-height: 1em;
margin: 0.1em 0.1em;
}
/* [[Template:Screen reader-only]] is canonical implementation onwiki */
.sr-only {
border: 0;
clip: rect(0, 0, 0, 0); /* removed from CSS */
clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
/* white-space: nowrap; /* already have nowrap above */
}
197429395812c1ab351775e9ab127ae0ef74564e
Coordinates
0
342
1129
455
2025-08-22T00:56:56Z
Sharparam
284703
Use {{tl|val}} again
wikitext
text/x-wiki
{{About|the game concept|specifying coordinates in a wiki article|Template:Coordinates}}
'''{{PAGENAME}}''' are used to indicate the player's location in the world.
== Overview ==
The player's coordinates consist of three components: the X, Y, and Z coordinate. X and Y denote the position on the horizontal plane, while Z is the vertical position (height).
== Bugs ==
* The coordinates as displayed inside the game on the inventory screen are often incorrect. The game truncates each coordinate value to only show the first four digits. As an example, if the player is at X coordinate {{val|13529}} (five digits), the game will show it as {{val|1352}} (four digits). To get an accurate position, usage of software that can enable the Unreal Engine debug HUD is required. If using the Unreal Engine Unlocker software, enable the debug HUD by using the <code>showdebug</code> command.
== External links ==
* [https://dev.epicgames.com/documentation/en-us/unreal-engine/coordinate-system-and-spaces-in-unreal-engine Coordinate System and Spaces] in the Unreal Engine documentation
[[Category:Game mechanics]]
4b2a35e53034534a2fd7a260f1c18bf681e114ed
Template:Para
10
733
1130
2025-08-22T01:04:13Z
Sharparam
284703
Created page with "<code class="tpl-para" style="word-break:break-word;{{SAFESUBST:<noinclude />#if:{{{plain|}}}|border: none; background-color: inherit;}} {{SAFESUBST:<noinclude />#if:{{{plain|}}}{{{mxt|}}}{{{green|}}}{{{!mxt|}}}{{{red|}}}|color: {{SAFESUBST:<noinclude />#if:{{{mxt|}}}{{{green|}}}|#006400|{{SAFESUBST:<noinclude />#if:{{{!mxt|}}}{{{red|}}}|#8B0000|inherit}}}};}} {{SAFESUBST:<noinclude />#if:{{{style|}}}|{{{style}}}}}">|{{SAFESUBST:<noinclude />#if:{{{1|}}}|{{{1}}}=..."
wikitext
text/x-wiki
<code class="tpl-para" style="word-break:break-word;{{SAFESUBST:<noinclude />#if:{{{plain|}}}|border: none; background-color: inherit;}} {{SAFESUBST:<noinclude />#if:{{{plain|}}}{{{mxt|}}}{{{green|}}}{{{!mxt|}}}{{{red|}}}|color: {{SAFESUBST:<noinclude />#if:{{{mxt|}}}{{{green|}}}|#006400|{{SAFESUBST:<noinclude />#if:{{{!mxt|}}}{{{red|}}}|#8B0000|inherit}}}};}} {{SAFESUBST:<noinclude />#if:{{{style|}}}|{{{style}}}}}">|{{SAFESUBST:<noinclude />#if:{{{1|}}}|{{{1}}}=}}{{{2|}}}</code><noinclude>
{{Documentation}}
<!--Categories and interwikis go near the bottom of the /doc subpage.-->
</noinclude>
06006deea2ed5d552aab61b4332321ab749ae7e8
Template:Para/doc
10
734
1131
2025-08-22T01:04:53Z
Sharparam
284703
Created page with "== External links == * [[wikipedia:Template:Para|Template and documentation on Wikipedia]] <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== External links ==
* [[wikipedia:Template:Para|Template and documentation on Wikipedia]]
<noinclude>[[Category:Template documentation]]</noinclude>
8ae906ad9a1b93d7d7300c0e02c2e6a8b63d28c7
Template:About/doc
10
735
1132
2025-08-22T01:07:58Z
Sharparam
284703
Created page with "<!-- Categories go where indicated at the bottom of this page, please. --> {{Tl|About}} is a commonly used [[wikipedia:WP:Hatnote|hatnote template]] for linking the reader to other articles with similar titles or concepts that they may have been seeking instead. ==Usage== This template should be [[wikipedia:WP:HATNOTEPLACE|placed]] at the top of an article (but following {{Tlx|Short description}}, if present). The template has several formats, including: *{{Tlx|About}}..."
wikitext
text/x-wiki
<!--
Categories go where indicated at the bottom of this page, please. -->
{{Tl|About}} is a commonly used [[wikipedia:WP:Hatnote|hatnote template]] for linking the reader to other articles with similar titles or concepts that they may have been seeking instead.
==Usage==
This template should be [[wikipedia:WP:HATNOTEPLACE|placed]] at the top of an article (but following {{Tlx|Short description}}, if present). The template has several formats, including:
*{{Tlx|About}} → {{About}}
*{{Tlx|About|Use1}} → {{About|Use1}}
*{{Tlx|About|<nowiki/>|Use2|Article2}} → {{About||Use2|Article2}}
*{{Tlx|About|<nowiki/>|<nowiki/>||Article (disambiguation)}} → {{About|||Article (disambiguation)}}
*{{Tlx|About|Use1|<nowiki/>|Article2}} → {{About|Use1||Article2}}
*{{Tlx|About|Use1|<nowiki/>|Article2|and|Article3}} → {{About|Use1||Article2|and|Article3}}
*{{Tlx|About|Use1|Use2|Article2}} → {{About|Use1|Use2|Article2}}
*{{Tlx|About|Use1|Use2|Article2|and|Article3}} → {{About|Use1|Use2|Article2|and|Article3}}
*{{Tlx|About|Use1|Use2|Article2|and|Article3|and|Article4|and|Article5}} → {{About|Use1|Use2|Article2|and|Article3|and|Article4|and|Article5}}
*{{Tlx|About|Use1|Use2|Article2|Use3|Article3}} → {{About|Use1|Use2|Article2|Use3|Article3}}
*{{Tlx|About|Use1|Use2|Article2|other uses}} → {{About|Use1|Use2|Article2|other uses}}
The template {{tl|For-multi}} produces the same hatnote, but without the initial ''This template is about''.
=== Styling in italics ===
Please see [[wikipedia:Wikipedia:Hatnote#Hatnotes with italics in the links]] ([[wikipedia:WP:ITHAT]]) for details about how to use italics in hatnotes.
==Parameters==
Alternately, a {{para|section|yes}} parameter can be added to the {{Tl|About}} template for use at the top of a section. When using this parameter, the wording in the template changes to specify that it is being used in a section:
*{{Tlx|About|Use1|<nowiki>section=yes</nowiki>}} → {{About|Use1|section=yes}}
*{{Tlx|About|Use1|<nowiki/>|Article2|<nowiki>section=yes</nowiki>}} → {{About|Use1||Article2|section=yes}}
*{{Tlx|About|Use1|Use2|Article2|<nowiki>section=yes</nowiki>}} → {{About|Use1|Use2|Article2|section=yes}}
*{{Tlx|About|Use1|Use2|Article2|and|Article3|<nowiki>section=yes</nowiki>}} → {{About|Use1|Use2|Article2|and|Article3|section=yes}}
*{{Tlx|About|Use1|Use2|Article2|other uses|<nowiki>section=yes</nowiki>}} → {{About|Use1|Use2|Article2|other uses|section=yes}}
A {{para|text}} option adds text to the end; this should only be used when truly necessary, when the other hatnote templates listed below don't suffice.
The {{para|selfref|yes}} option marks the entire hatnote as a Wikipedia self-reference, causing it to be omitted when the page content is reused outside of Wikipedia (see {{tl|self reference}} and [[wikipedia:MOS:SELFREF]] for more details).
For more options, see section "TemplateData" below.
==TemplateData==
<!--{{TemplateData header}}-->
<!-- Should this mention the existence of "and"? It's something of a can of worms, since it only looks as though it only works in certain combinations of the other page 2/3/4 description fields... -->
<templatedata>
{
"description": "This template is a hatnote in the format \"This page is about … For other uses …\".",
"params": {
"1": {
"label": "Page description",
"type": "string",
"description": "What the page this template is placed on is about (\"This page is about …\")",
"suggested": true
},
"2": {
"label": "Other page 1 description",
"type": "string",
"description": "What the first other page is about. If unused or blank, defaults to \"other uses\".",
"suggested": true
},
"3": {
"label": "Other page 1 title",
"type": "wiki-page-name",
"description": "The title of the first other page. If unused, defaults to \"[page title] (disambiguation)\".",
"suggested": true
},
"4": {
"label": "Other page 2 description",
"type": "string",
"description": "What the second other page is about."
},
"5": {
"label": "Other page 2 title",
"type": "wiki-page-name",
"description": "The title of the second other page. If unused or blank and parameter 4 exists, defaults to \"[page title] (disambiguation)\"."
},
"6": {
"label": "Other page 3 description",
"type": "string",
"description": "What the third other page is about."
},
"7": {
"label": "Other page 3 title",
"type": "wiki-page-name",
"description": "The title of the third other page. If unused or blank and parameter 6 exists, defaults to \"[page title] (disambiguation)\"."
},
"8": {
"label": "Other page 4 description",
"type": "string",
"description": "What the fourth other page is about."
},
"9": {
"label": "Other page 4 title",
"type": "wiki-page-name",
"description": "The title of the fourth other page. If unused or blank and parameter 8 exists, defaults to \"[page title] (disambiguation)\"."
},
"section": {
"type": "string",
"description": "Pass \"yes\" in this parameter to get wording appropriate for use at the top of a section.",
"autovalue": "yes"
},
"text": {
"label": "Custom text",
"type": "string",
"description": "Text to be appended to the end."
}
}
}
</templatedata>
==See also==
* [[wikipedia:Wikipedia:Hatnote]]
<!--{{Hatnote templates}}-->
<!-- To add more other pages, continue with this alternating pattern using increasing numbers, starting with 6 for the next page description. -->
<includeonly>{{Sandbox other||
<!-- Categories go below this line, please; interwikis go to Wikidata, thank you! -->
[[Category:Disambiguation and redirection hatnote templates]]
}}</includeonly>
979c2e2e08324dcf5adc700fd845b19dfeaacf79
Module:Hatnote
828
338
1133
444
2025-08-22T01:17:45Z
Sharparam
284703
Add support for icon
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Hatnote --
-- --
-- This module produces hatnote links and links to related articles. It --
-- implements the {{hatnote}} and {{format link}} meta-templates and includes --
-- helper functions for other Lua hatnote modules. --
--------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local checkTypeForNamedArg = libraryUtil.checkTypeForNamedArg
local mArguments -- lazily initialise [[Module:Arguments]]
local yesno -- lazily initialise [[Module:Yesno]]
local formatLink -- lazily initialise [[Module:Format link]] ._formatLink
local p = {}
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
local function getArgs(frame)
-- Fetches the arguments from the parent frame. Whitespace is trimmed and
-- blanks are removed.
mArguments = require('Module:Arguments')
return mArguments.getArgs(frame, {parentOnly = true})
end
local function removeInitialColon(s)
-- Removes the initial colon from a string, if present.
return s:match('^:?(.*)')
end
function p.defaultClasses(inline)
-- Provides the default hatnote classes as a space-separated string; useful
-- for hatnote-manipulation modules like [[Module:Hatnote group]].
return
(inline == 1 and 'hatnote-inline' or 'hatnote') .. ' ' ..
'navigation-not-searchable'
end
function p.disambiguate(page, disambiguator)
-- Formats a page title with a disambiguation parenthetical,
-- i.e. "Example" → "Example (disambiguation)".
checkType('disambiguate', 1, page, 'string')
checkType('disambiguate', 2, disambiguator, 'string', true)
disambiguator = disambiguator or 'disambiguation'
return mw.ustring.format('%s (%s)', page, disambiguator)
end
function p.findNamespaceId(link, removeColon)
-- Finds the namespace id (namespace number) of a link or a pagename. This
-- function will not work if the link is enclosed in double brackets. Colons
-- are trimmed from the start of the link by default. To skip colon
-- trimming, set the removeColon parameter to false.
checkType('findNamespaceId', 1, link, 'string')
checkType('findNamespaceId', 2, removeColon, 'boolean', true)
if removeColon ~= false then
link = removeInitialColon(link)
end
local namespace = link:match('^(.-):')
if namespace then
local nsTable = mw.site.namespaces[namespace]
if nsTable then
return nsTable.id
end
end
return 0
end
function p.makeWikitextError(msg, helpLink, addTrackingCategory, title)
-- Formats an error message to be returned to wikitext. If
-- addTrackingCategory is not false after being returned from
-- [[Module:Yesno]], and if we are not on a talk page, a tracking category
-- is added.
checkType('makeWikitextError', 1, msg, 'string')
checkType('makeWikitextError', 2, helpLink, 'string', true)
yesno = require('Module:Yesno')
title = title or mw.title.getCurrentTitle()
-- Make the help link text.
local helpText
if helpLink then
helpText = ' ([[' .. helpLink .. '|help]])'
else
helpText = ''
end
-- Make the category text.
local category
if not title.isTalkPage -- Don't categorise talk pages
and title.namespace ~= 2 -- Don't categorise userspace
and yesno(addTrackingCategory) ~= false -- Allow opting out
then
category = 'Hatnote templates with errors'
category = mw.ustring.format(
'[[%s:%s]]',
mw.site.namespaces[14].name,
category
)
else
category = ''
end
return mw.ustring.format(
'<strong class="error">Error: %s%s.</strong>%s',
msg,
helpText,
category
)
end
local curNs = mw.title.getCurrentTitle().namespace
p.missingTargetCat =
--Default missing target category, exported for use in related modules
((curNs == 0) or (curNs == 14)) and
'Articles with hatnote templates targeting a nonexistent page' or nil
function p.quote(title)
--Wraps titles in quotation marks. If the title starts/ends with a quotation
--mark, kerns that side as with {{-'}}
local quotationMarks = {
["'"]=true, ['"']=true, ['“']=true, ["‘"]=true, ['”']=true, ["’"]=true
}
local quoteLeft, quoteRight = -- Test if start/end are quotation marks
quotationMarks[string.sub(title, 1, 1)],
quotationMarks[string.sub(title, -1, -1)]
if quoteLeft or quoteRight then
title = mw.html.create("span"):wikitext(title)
end
if quoteLeft then title:css("padding-left", "0.15em") end
if quoteRight then title:css("padding-right", "0.15em") end
return '"' .. tostring(title) .. '"'
end
--------------------------------------------------------------------------------
-- Hatnote
--
-- Produces standard hatnote text. Implements the {{hatnote}} template.
--------------------------------------------------------------------------------
p[''] = function (frame) return p.hatnote(frame:newChild{ title = "Template:Hatnote" }) end
function p.hatnote(frame)
local args = getArgs(frame)
local s = args[1]
if not s then
return p.makeWikitextError(
'no text specified',
'Template:Hatnote#Errors',
args.category
)
end
return p._hatnote(s, {
extraclasses = args.extraclasses,
selfref = args.selfref,
icon = args.icon
})
end
function p._hatnote(s, options)
checkType('_hatnote', 1, s, 'string')
checkType('_hatnote', 2, options, 'table', true)
options = options or {}
local inline = options.inline
local hatnote = mw.html.create(inline == 1 and 'span' or 'div')
local extraclasses
if type(options.extraclasses) == 'string' then
extraclasses = options.extraclasses
end
if options.icon then
s = "[[File:" .. options.icon .. "|x22px]]<nowiki> </nowiki>" .. s
end
hatnote
:attr('role', 'note')
:addClass(p.defaultClasses(inline))
:addClass(extraclasses)
:addClass(options.selfref and 'selfref' or nil)
:wikitext(s)
return mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Module:Hatnote/styles.css' }
} .. tostring(hatnote)
end
return p
d64ac2e25fd54ca6e166cec9072b7aa98428e6a6
Module:About/doc
828
736
1134
2025-08-22T01:21:54Z
Sharparam
284703
Created page with "<!-- Please place categories where indicated at the bottom of this page --> This module implements the {{tl|about}} [[wikipedia:Wikipedia:Hatnote|hatnote]] template. == Usage == *The <code>about</code> function implements the {{tl|about}} template directly, using the frame and applying no options. This should probably only be used in {{tl|about}}. *The <code>_about</code> function can be used from Lua to supply a custom arguments list (its first argument) and/or an opt..."
wikitext
text/x-wiki
<!-- Please place categories where indicated at the bottom of this page -->
This module implements the {{tl|about}} [[wikipedia:Wikipedia:Hatnote|hatnote]] template.
== Usage ==
*The <code>about</code> function implements the {{tl|about}} template directly, using the frame and applying no options. This should probably only be used in {{tl|about}}.
*The <code>_about</code> function can be used from Lua to supply a custom arguments list (its first argument) and/or an options table (its second argument). Options include:
**<code>aboutForm</code> A string that can be used to substitute the form of the initial "about" message. It should include two substitution points: the first for the page type (e.g. "article"), and the second for the description of what the page is about. It should also include a trailing space for easy concatenation or omission. Defaults to <code>'This %s is about %s. '</code>.
**<code>sectionString</code> Gives the page type string for when the named argument <code>section</code> is specified. Defaults to <code>'section'</code>.
== Examples ==
* {{#invoke:about|about|disambiguation}}
<includeonly>{{Sandbox other||
<!-- Categories below this line, please; interwikis at Wikidata -->
[[Category:Hatnote modules]]
}}</includeonly>
ad89dfe0b6218335ce723e879ab0c16dedb02eb3
Module:About
828
339
1135
446
2025-08-22T01:23:37Z
Sharparam
284703
Set an icon
Scribunto
text/plain
local mArguments --initialize lazily
local mHatnote = require('Module:Hatnote')
local mHatList = require('Module:Hatnote list')
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
function p.about (frame)
-- A passthrough that gets args from the frame and all
mArguments = require('Module:Arguments')
args = mArguments.getArgs(frame)
return p._about(args)
end
function p._about (args, options)
-- Produces "about" hatnote.
-- Type checks and defaults
checkType('_about', 1, args, 'table', true)
args = args or {}
checkType('_about', 2, options, 'table', true)
options = options or {}
local defaultOptions = {
aboutForm = 'This %s is about %s. ',
PageType = require('Module:Pagetype').main(),
otherText = nil, --included for complete list
sectionString = 'section'
}
for k, v in pairs(defaultOptions) do
if options[k] == nil then options[k] = v end
end
-- Set initial "about" string
local pageType = (args.section and options.sectionString) or options.PageType
local about = ''
if args[1] then
about = string.format(options.aboutForm, pageType, args[1])
end
--Allow passing through certain options
local fsOptions = {
otherText = options.otherText,
extratext = args.text
}
local hnOptions = {
selfref = args.selfref
}
if not args.noicon then hnOptions.icon = args.icon or "Disambig.svg" end
-- Set for-see list
local forSee = mHatList._forSee(args, 2, fsOptions)
-- Concatenate and return
return mHatnote._hatnote(about .. forSee, hnOptions)
end
return p
acef7e76987e5cbb64cae252e876f16e8b980a9a
Module:Hatnote
828
338
1136
1133
2025-08-22T01:25:40Z
Sharparam
284703
Use nbsp instead of nowiki tag
Scribunto
text/plain
--------------------------------------------------------------------------------
-- Module:Hatnote --
-- --
-- This module produces hatnote links and links to related articles. It --
-- implements the {{hatnote}} and {{format link}} meta-templates and includes --
-- helper functions for other Lua hatnote modules. --
--------------------------------------------------------------------------------
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local checkTypeForNamedArg = libraryUtil.checkTypeForNamedArg
local mArguments -- lazily initialise [[Module:Arguments]]
local yesno -- lazily initialise [[Module:Yesno]]
local formatLink -- lazily initialise [[Module:Format link]] ._formatLink
local p = {}
--------------------------------------------------------------------------------
-- Helper functions
--------------------------------------------------------------------------------
local function getArgs(frame)
-- Fetches the arguments from the parent frame. Whitespace is trimmed and
-- blanks are removed.
mArguments = require('Module:Arguments')
return mArguments.getArgs(frame, {parentOnly = true})
end
local function removeInitialColon(s)
-- Removes the initial colon from a string, if present.
return s:match('^:?(.*)')
end
function p.defaultClasses(inline)
-- Provides the default hatnote classes as a space-separated string; useful
-- for hatnote-manipulation modules like [[Module:Hatnote group]].
return
(inline == 1 and 'hatnote-inline' or 'hatnote') .. ' ' ..
'navigation-not-searchable'
end
function p.disambiguate(page, disambiguator)
-- Formats a page title with a disambiguation parenthetical,
-- i.e. "Example" → "Example (disambiguation)".
checkType('disambiguate', 1, page, 'string')
checkType('disambiguate', 2, disambiguator, 'string', true)
disambiguator = disambiguator or 'disambiguation'
return mw.ustring.format('%s (%s)', page, disambiguator)
end
function p.findNamespaceId(link, removeColon)
-- Finds the namespace id (namespace number) of a link or a pagename. This
-- function will not work if the link is enclosed in double brackets. Colons
-- are trimmed from the start of the link by default. To skip colon
-- trimming, set the removeColon parameter to false.
checkType('findNamespaceId', 1, link, 'string')
checkType('findNamespaceId', 2, removeColon, 'boolean', true)
if removeColon ~= false then
link = removeInitialColon(link)
end
local namespace = link:match('^(.-):')
if namespace then
local nsTable = mw.site.namespaces[namespace]
if nsTable then
return nsTable.id
end
end
return 0
end
function p.makeWikitextError(msg, helpLink, addTrackingCategory, title)
-- Formats an error message to be returned to wikitext. If
-- addTrackingCategory is not false after being returned from
-- [[Module:Yesno]], and if we are not on a talk page, a tracking category
-- is added.
checkType('makeWikitextError', 1, msg, 'string')
checkType('makeWikitextError', 2, helpLink, 'string', true)
yesno = require('Module:Yesno')
title = title or mw.title.getCurrentTitle()
-- Make the help link text.
local helpText
if helpLink then
helpText = ' ([[' .. helpLink .. '|help]])'
else
helpText = ''
end
-- Make the category text.
local category
if not title.isTalkPage -- Don't categorise talk pages
and title.namespace ~= 2 -- Don't categorise userspace
and yesno(addTrackingCategory) ~= false -- Allow opting out
then
category = 'Hatnote templates with errors'
category = mw.ustring.format(
'[[%s:%s]]',
mw.site.namespaces[14].name,
category
)
else
category = ''
end
return mw.ustring.format(
'<strong class="error">Error: %s%s.</strong>%s',
msg,
helpText,
category
)
end
local curNs = mw.title.getCurrentTitle().namespace
p.missingTargetCat =
--Default missing target category, exported for use in related modules
((curNs == 0) or (curNs == 14)) and
'Articles with hatnote templates targeting a nonexistent page' or nil
function p.quote(title)
--Wraps titles in quotation marks. If the title starts/ends with a quotation
--mark, kerns that side as with {{-'}}
local quotationMarks = {
["'"]=true, ['"']=true, ['“']=true, ["‘"]=true, ['”']=true, ["’"]=true
}
local quoteLeft, quoteRight = -- Test if start/end are quotation marks
quotationMarks[string.sub(title, 1, 1)],
quotationMarks[string.sub(title, -1, -1)]
if quoteLeft or quoteRight then
title = mw.html.create("span"):wikitext(title)
end
if quoteLeft then title:css("padding-left", "0.15em") end
if quoteRight then title:css("padding-right", "0.15em") end
return '"' .. tostring(title) .. '"'
end
--------------------------------------------------------------------------------
-- Hatnote
--
-- Produces standard hatnote text. Implements the {{hatnote}} template.
--------------------------------------------------------------------------------
p[''] = function (frame) return p.hatnote(frame:newChild{ title = "Template:Hatnote" }) end
function p.hatnote(frame)
local args = getArgs(frame)
local s = args[1]
if not s then
return p.makeWikitextError(
'no text specified',
'Template:Hatnote#Errors',
args.category
)
end
return p._hatnote(s, {
extraclasses = args.extraclasses,
selfref = args.selfref,
icon = args.icon
})
end
function p._hatnote(s, options)
checkType('_hatnote', 1, s, 'string')
checkType('_hatnote', 2, options, 'table', true)
options = options or {}
local inline = options.inline
local hatnote = mw.html.create(inline == 1 and 'span' or 'div')
local extraclasses
if type(options.extraclasses) == 'string' then
extraclasses = options.extraclasses
end
if options.icon then
s = "[[File:" .. options.icon .. "|x22px]] " .. s
end
hatnote
:attr('role', 'note')
:addClass(p.defaultClasses(inline))
:addClass(extraclasses)
:addClass(options.selfref and 'selfref' or nil)
:wikitext(s)
return mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Module:Hatnote/styles.css' }
} .. tostring(hatnote)
end
return p
091300bfb29ce9b01a1d4dc1da72ab20f2626119
File:OrientalSpin.png
6
737
1137
2025-08-22T01:28:42Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_OrientalSpin
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_OrientalSpin
}}
== Licensing ==
{{License|game}}
d8bfd3f92a2c9aea494cf47fe9c8809e50bca9a6
File:OrientalDash.png
6
738
1138
2025-08-22T01:29:29Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_OrientalDash
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_OrientalDash
}}
== Licensing ==
{{License|game}}
b923ea1591e8c5bfa6d06623e2d555c4ae527c36
File:Divine Blessing.png
6
739
1139
2025-08-22T01:30:11Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_DivineBlessing
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_DivineBlessing
}}
== Licensing ==
{{License|game}}
eef9d3c7cbbdc0f9694687aa8f9380456c9dedeb
File:Site-favicon.ico
6
283
1140
308
2025-08-22T01:32:14Z
Sharparam
284703
Changed protection settings for "[[File:Site-favicon.ico]]": Favicon used for the entire site ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite) [Upload=Allow only administrators] (indefinite))
wikitext
text/x-wiki
== Licensing ==
{{License|game}}
5fdc0517c60eec1aa02a1fef9763fa88c38be9ad
User:Sharparam/common.js
2
740
1141
2025-08-22T01:36:53Z
Sharparam
284703
Created page with "mw.loader.load( '//en.wikipedia.org/w/index.php?title=User:Joeytje50/JWB.js/load.js&action=raw&ctype=text/javascript' ); // Backlink: [[en:User:Joeytje50/JWB.js/load.js]]"
javascript
text/javascript
mw.loader.load( '//en.wikipedia.org/w/index.php?title=User:Joeytje50/JWB.js/load.js&action=raw&ctype=text/javascript' ); // Backlink: [[en:User:Joeytje50/JWB.js/load.js]]
ac852b5cb6bbc8c580ce7702ab0c747386409016
Blok 6174
0
741
1143
1142
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[Blok 6147]]
3ee370bab2292ee469f53ad5d06af212bbb3db85
Captain Yulia
0
742
1145
1144
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[Royal Division Captain Yulia]]
944a6e86bec704d704b6109fc690822aa40d60b9
Dual Wield Mastery
0
743
1147
1146
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
[[File:Dual_Wield_Mastery.png|thumb]]
'''{{PAGENAME}}''' is a [[perk]] in {{BFF}}. It improves proficiency with [[dual wield]] [[weapons]].
== Effect ==
Offhand weapons now deal 60% of their damage instead of 35%.
== Upgrades ==
* Critical Chance increases by 1% with each combo point while dual wielding.
* While dual wielding, you do not consume any stamina for melee attacks if at 15 or above combo points.
{{Navbox/Perks}}
[[Category:Perks]]
78e20c9ebd95bf46994bc694995631a11d79d8b6
Improved Diver's Lungs Concoction
0
744
1149
1148
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
== Recipe ==
Obtained by defeating the many-legged creature in [[Deluge]].
a1b23855f2d6d50d291ff7ec5da567ce7c83641d
Librarian
0
745
1151
1150
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''Librarian''' may refer to:
== Common meanings ==
* [[Librarian (armor set)]], a light armor set
* [[Librarian (enemy)]], the enemy in the [[Monastery]]
== See also ==
* [[Librarian Hood]]
* [[Librarian Overcoat]]
* [[Librarian Trousers]]
{{Disambiguation}}
c7eb5b123cb7063d1af9038ba92b3013df3b5b50
Perk
0
746
1153
1152
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[Perks]]
22eac196aff02ba31a4bced80e80fcfdc8051202
Perks
0
747
1155
1154
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful passive upgrades in {{BFF}}. The player can have up to four active perks at one time.
{{Navbox/Perks}}
26af41c73ec1c4e20599336d60d88a8378c8c6ab
1180
1155
2025-08-22T09:24:46Z
Sharparam
284703
Add category
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful passive upgrades in {{BFF}}. The player can have up to four active perks at one time.
{{Navbox/Perks}}
[[Category:Perks]]
d2a40a35f7371d4439016c2e06a6a0ad6ee3d71e
Ring of Serpent
0
748
1157
1156
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Ring
| image = Ring of Serpent.png
| title = {{PAGENAME}}
| Passives = [[Swift Reflexes]]
| Effect1 = +2 [[Agility]]
}}
== Location ==
Near one of the underwater red lights in [[Deluge]].
{{Navbox/Rings}}
66cfb985c30744dba393ecfef89461918d2773f8
Saracen Shield
0
749
1159
1158
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Saracen Shield.png
| Weight = Heavy
| Abilities = [[Regal Radiance]]
| Mk2_Sharp = 59.5
| Mk2_Blunt = 57.4
| Mk2_Technomancy = 69.3
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Location ==
{{cords|3760|1142|-1395}}
Found in the [[Desert]]. In the area with Yaroslav's crew, look behind the big statue head to find the shield.
{{Navbox/Shields}}
59fda45f4bdf41eba1f4a2bcf8c2764d16851685
Spiked Shield
0
750
1161
1160
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Spiked Shield.png
| Weight = Heavy
| Passives = [[Spikes]]
| Mk0_Sharp = 48.6
| Mk0_Blunt = 54.6
| Mk0_Technomancy = 49.8
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Acquisition ==
Dropped by [[Plagued Warden]].
{{Navbox/Shields}}
35d72a537a85e4efbf9cffb04c27d03f7ce129cf
Tall Military Shield
0
751
1163
1162
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Shield
| image = Tall Military Shield.png
| title = {{PAGENAME}}
| Weight = Heavy
| Abilities = [[Improvised Fortification]]
| Mk2_Sharp = 59.5
| Mk2_Blunt = 66.5
| Mk2_Technomancy = 52.5
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] that can be equipped by the player. It is the tall version of [[Military Shield|the Military Shield]].
== Location ==
{{coords|-4043|1327|1056}}
Found in [[Asylum]]. After climbing a set of stars inside the first building after the courtyard, the item is at the top on one of the catwalks.
{{Navbox/Shields}}
181aab1accc7978058774e9cab9eea6c94c3154c
Tech Shield
0
752
1165
1164
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Tech Shield.png
| Weight = Heavy
| Abilities = [[Refraction]]
| Mk2_Sharp = 42.7
| Mk2_Blunt = 47.6
| Mk2_Technomancy = 70
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Location ==
{{coords|1327|-9333|1892}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. Starting at the [[Homunculus]], head through the doorway and take the path on the left. After reaching the outdoors area, head up the stairs and take the left path. At the end is a cliff, climb it by standing near it and repeatedly tapping the jump button. Once on top of the cliff, go to the right and you'll see the corpse with the item against a cliff wall.
On the same corpse can also be found the [[Ring of Rammstein]].
{{Navbox/Shields}}
1e64b4aa14aac12ca5c32867c37f664acb36dedf
Vermillion Mirage
0
753
1167
1166
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
#REDIRECT [[Royal Division Captain Yulia & Vermillion Mirage]]
a706f52584d29641b5b3d4ebd9403828f396a0e3
Wooden Shield
0
754
1169
1168
2025-08-22T09:16:38Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{Infobox/Shield
| image = Wooden Shield.png
| title = {{PAGENAME}}
| Weight = Light
| Mk0_Sharp = 52.8
| Mk0_Blunt = 46.8
| Mk0_Technomancy = 7.2
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
{{Navbox/Shields}}
a25cde7cfde39f917e98c499b4c23d236886a94f
File:Wooden Shield.png
6
755
1170
2025-08-22T09:17:39Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_WoodenShield
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_WoodenShield
}}
== Licensing ==
{{License|game}}
65508572de4edc9222f8c1c667c5020f6d0fddc4
File:Tech Shield.png
6
756
1171
2025-08-22T09:18:33Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_TechShield
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_TechShield
}}
== Licensing ==
{{License|game}}
53a27f76eadb3cf7a3d774086d9e55de6edb33b1
File:Tall Military Shield.png
6
757
1172
2025-08-22T09:19:10Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_TallMilitaryShield
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_TallMilitaryShield
}}
== Licensing ==
{{License|game}}
df5b45ff8cfd7e7372508c13ab75e10f21dc3420
File:Spiked Shield.png
6
758
1173
2025-08-22T09:19:50Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/icon_spikedshield
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/icon_spikedshield
}}
== Licensing ==
{{License|game}}
50d0b50e059bfba7957bc670777b1cb0c168a443
File:Saracen Shield.png
6
759
1174
2025-08-22T09:20:25Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_SaracenShield
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_SaracenShield
}}
== Licensing ==
{{License|game}}
c19959878faaa9e9fa1530b62b6ea1806329b9b1
Template:Navbox/Rings
10
292
1175
376
2025-08-22T09:20:56Z
Sharparam
284703
Add [[Ring of Serpent]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Burning Desire]]
* [[Ring of Casting Speed]]
* [[Ring of Hawk]]
* [[Ring of Rammstein]]
* [[Ring of Serpent]]
* [[Ring of Lesser Talent]]
* [[Ring of Talent]]
* [[Ring of Exceeding Talent]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
1bf7926b4eef3b181e1771fd1c0e79707833bf81
Template:Navbox/Perks
10
760
1176
2025-08-22T09:21:40Z
Sharparam
284703
Created page with "{{Navbox | template = Navbox/Perks | title = [[Perks]] | list1 = * [[Archery Mastery]] * [[Berserker]] * [[Combo Brutality]] * [[Companions]] * [[Debuff Mastery]] * [[Dual Wield Mastery]] * [[Duellist]] * [[Faithful]] * [[Illusionist]] * [[Impenetrable Fortress]] * [[Mindbreaker]] * [[Natural Talent]] * [[Shield Mastery]] * [[Technomancer]] * [[Tinkerer Mastery]] * [[Vampirism]] * [[Vindicator]] * [[Zealot]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Perks
| title = [[Perks]]
| list1 =
* [[Archery Mastery]]
* [[Berserker]]
* [[Combo Brutality]]
* [[Companions]]
* [[Debuff Mastery]]
* [[Dual Wield Mastery]]
* [[Duellist]]
* [[Faithful]]
* [[Illusionist]]
* [[Impenetrable Fortress]]
* [[Mindbreaker]]
* [[Natural Talent]]
* [[Shield Mastery]]
* [[Technomancer]]
* [[Tinkerer Mastery]]
* [[Vampirism]]
* [[Vindicator]]
* [[Zealot]]
}}<noinclude>{{Documentation}}</noinclude>
abe876ef8a1c6f16d735fa1468f3cc9921221f03
Template:Navbox/Perks/doc
10
761
1177
2025-08-22T09:22:09Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
87827f6829955b934e0e8073491c0fef23954bf8
File:Dual Wield Mastery.png
6
762
1178
2025-08-22T09:24:06Z
Sharparam
284703
{{Game image
| path = Game/Textures/Perks/Icons/Dual
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Perks/Icons/Dual
}}
== Licensing ==
{{License|game}}
c570af8c6721a2242f2b71c9db9950d9ee24c748
Category:Perks
14
763
1179
2025-08-22T09:24:30Z
Sharparam
284703
Created page with "[[Perks]] in {{BFF}}."
wikitext
text/x-wiki
[[Perks]] in {{BFF}}.
3f01150d30482ed76f3efc2cc207ab62eefb4b45
Template:Disambiguation (wiki.gg)
10
105
1181
127
2025-08-22T09:27:21Z
Sharparam
284703
Sharparam renamed page [[Template:Disambiguation]] to [[Template:Disambiguation (wiki.gg)]] without leaving a redirect: Switching to a version more similar to WP's Disambiguation template
wikitext
text/x-wiki
<includeonly><!--
-->{{#vardefine:topic|<!-- start vd
-->{{#if:{{{topic|}}} | {{{topic}}} | {{PAGENAME}} }}<!-- end if
-->}}<!-- end vd
-->{{#vardefine:disambig|<!-- start vd
-->{{#if:{{{1|}}}<!-- start custom disambig if
-->|{{{1}}}<!-- start label if -->{{#if:{{{2|}}} | {{!}}{{{2}}} }}<!-- end label if
-->|{{#var:topic}} (disambiguation)<!-- else; use regular disambig
-->}}<!-- end custom disambig if
-->}}<!-- end vd
-->{{Hatnote|<!--
-->This page is about '''{{#var:topic}}'''. For other uses, see [[{{#var:disambig}}]].<!--
-->|icon=Disambig.svg<!--
-->}}<!--
--></includeonly><!--
--><noinclude>{{doc}}[[Category:Hatnote templates]]</noinclude>
c4c62e7a1876492eb970ea182cf4ac0bcad97913
Template:Disambiguation (wiki.gg)/doc
10
104
1182
126
2025-08-22T09:27:21Z
Sharparam
284703
Sharparam renamed page [[Template:Disambiguation/doc]] to [[Template:Disambiguation (wiki.gg)/doc]] without leaving a redirect: Switching to a version more similar to WP's Disambiguation template
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Disambiguation Page",
"description": "A custom disambiguation page name.",
"example": "Disambiguation Page",
"type": "wiki-page-name"
},
"2": {
"label": "Link Label",
"description": "A label for the custom disambiguation page.",
"example": "Alternative Page Name",
"type": "line"
},
"topic": {
"label": "Custom Topic",
"description": "In case {{PAGENAME}} does not describe the topic, this can be used to display a custom topic",
"example": "a custom topic",
"default": "{{PAGENAME}}",
"type": "line"
}
},
"description": "This hatnote template is meant to be used at the top of an article to indicate the existence of a disambiguation page.",
"paramOrder": [
"1",
"2",
"topic"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Disambiguation}}</nowiki></code> || {{Disambiguation|topic=Example}}
|-
| <code><nowiki>{{Disambiguation|Special:Random|topic=Example}}</nowiki></code> || {{Disambiguation|Special:Random|topic=Example}}
|-
| <code><nowiki>{{Disambiguation|Special:Random|Page Label|topic=this particular topic}}</nowiki></code> || {{Disambiguation|Special:Random|Page Label|topic=this particular topic}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The {{tl|Hatnote}} base template.
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
== Source ==
Roughly based on [[wikipedia:Template:About|Wikipedia's About Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
5fce9c689120c57454571ff0e60a2cd447df5713
1185
1182
2025-08-22T09:30:40Z
Sharparam
284703
Fix examples
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Disambiguation Page",
"description": "A custom disambiguation page name.",
"example": "Disambiguation Page",
"type": "wiki-page-name"
},
"2": {
"label": "Link Label",
"description": "A label for the custom disambiguation page.",
"example": "Alternative Page Name",
"type": "line"
},
"topic": {
"label": "Custom Topic",
"description": "In case {{PAGENAME}} does not describe the topic, this can be used to display a custom topic",
"example": "a custom topic",
"default": "{{PAGENAME}}",
"type": "line"
}
},
"description": "This hatnote template is meant to be used at the top of an article to indicate the existence of a disambiguation page.",
"paramOrder": [
"1",
"2",
"topic"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Disambiguation (wiki.gg}}</nowiki></code> || {{Disambiguation (wiki.gg)|topic=Example}}
|-
| <code><nowiki>{{Disambiguation (wiki.gg)|Special:Random|topic=Example}}</nowiki></code> || {{Disambiguation (wiki.gg)|Special:Random|topic=Example}}
|-
| <code><nowiki>{{Disambiguation (wiki.gg)|Special:Random|Page Label|topic=this particular topic}}</nowiki></code> || {{Disambiguation (wiki.gg)|Special:Random|Page Label|topic=this particular topic}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The {{tl|Hatnote}} base template.
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
== Source ==
Roughly based on [[wikipedia:Template:About|Wikipedia's About Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
66a58f9b7bd1fcafab8c196a7f377e84c344bd01
1186
1185
2025-08-22T09:30:59Z
Sharparam
284703
/* Examples */ Fix missing paren in example
wikitext
text/x-wiki
<templatedata>
{
"params": {
"1": {
"label": "Disambiguation Page",
"description": "A custom disambiguation page name.",
"example": "Disambiguation Page",
"type": "wiki-page-name"
},
"2": {
"label": "Link Label",
"description": "A label for the custom disambiguation page.",
"example": "Alternative Page Name",
"type": "line"
},
"topic": {
"label": "Custom Topic",
"description": "In case {{PAGENAME}} does not describe the topic, this can be used to display a custom topic",
"example": "a custom topic",
"default": "{{PAGENAME}}",
"type": "line"
}
},
"description": "This hatnote template is meant to be used at the top of an article to indicate the existence of a disambiguation page.",
"paramOrder": [
"1",
"2",
"topic"
],
"format": "inline"
}
</templatedata>
== Examples ==
{| class="wikitable"
! Code !! Result
|-
| <code><nowiki>{{Disambiguation (wiki.gg)}}</nowiki></code> || {{Disambiguation (wiki.gg)|topic=Example}}
|-
| <code><nowiki>{{Disambiguation (wiki.gg)|Special:Random|topic=Example}}</nowiki></code> || {{Disambiguation (wiki.gg)|Special:Random|topic=Example}}
|-
| <code><nowiki>{{Disambiguation (wiki.gg)|Special:Random|Page Label|topic=this particular topic}}</nowiki></code> || {{Disambiguation (wiki.gg)|Special:Random|Page Label|topic=this particular topic}}
|}
== Dependencies ==
For this template to work properly, you need the following:
* The {{tl|Hatnote}} base template.
* The <code>.hatnote</code> class, found in [[MediaWiki:Common.css]].
== Source ==
Roughly based on [[wikipedia:Template:About|Wikipedia's About Template]].
<noinclude>[[Category:Template documentation]]</noinclude>
b603298f6af054c214e7459e026fa92f9ff23fc2
Template:Disambiguation
10
764
1183
2025-08-22T09:27:49Z
Sharparam
284703
Heavily simplified form of [[wikipedia:Template:Disambiguation]]
wikitext
text/x-wiki
<includeonly>{{#if:{{NAMESPACE}}||[[Category:Disambiguation pages]]}}</includeonly><noinclude>{{Documentation}}</noinclude>
f54474067961aa4345e7a2b4d76d7bf1334f39f9
1188
1183
2025-08-22T09:36:31Z
Sharparam
284703
Add disambiguation magic word
wikitext
text/x-wiki
<includeonly>
{{#if:{{NAMESPACE}}|
|__DISAMBIG__ [[Category:Disambiguation pages]]
}}
</includeonly><noinclude>{{Documentation}}</noinclude>
e47f8fb1d8dcf2b726b5a0246e8a356dad403d06
Template:Disambiguation/doc
10
765
1184
2025-08-22T09:29:42Z
Sharparam
284703
Created page with "Place at the end of disambiguation pages to put them in the proper category. == Usage == {{tl|Disambiguation}} <includeonly>{{Sandbox other||[[Category:Disambiguation templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
Place at the end of disambiguation pages to put them in the proper category.
== Usage ==
{{tl|Disambiguation}}
<includeonly>{{Sandbox other||[[Category:Disambiguation templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
5c29d2096ac5de472ee1486183db375da0b06bad
Category:Disambiguation pages
14
766
1187
2025-08-22T09:33:15Z
Sharparam
284703
Created page with "Pages that serve to disambiguate topics/names that have multiple meanings. Places pages into this category by using the {{tl|Disambiguation}} template on a page. == External links == * [[:wikipedia:Category:Disambiguation pages|Disambiguation pages category]] on Wikipedia."
wikitext
text/x-wiki
Pages that serve to disambiguate topics/names that have multiple meanings. Places pages into this category by using the {{tl|Disambiguation}} template on a page.
== External links ==
* [[:wikipedia:Category:Disambiguation pages|Disambiguation pages category]] on Wikipedia.
645e1e0deadd54cd5f0aabe5da7a6a5bc838077d
Template:Infobox/Armor
10
453
1189
1069
2025-08-22T09:39:48Z
Sharparam
284703
Add special handling for librarian armor set
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Weight,Set,Passives
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| helmet = [[Helmet]]
| pauldrons = [[Pauldrons]]
| chestguard = [[Chestguard]]
| legguard = [[Legguard]]
| gauntlet = [[Gauntlet]]
| #default = {{{Type}}}
}}}}
|Set={{#if:{{{Set|}}}|{{#switch:{{lc:{{{Set}}}
| librarian = [[Librarian (armor set)|Librarian]]
| #default = [[{{{Set}}}]]
}}}}}}
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \!
| token = @@@@
| pattern = [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| helmet = [[Category:Helmets]]
| pauldrons = [[Category:Pauldrons]]
| chestguard = [[Category:Chestguards]]
| legguard = [[Category:Legguards]]
| gauntlet = [[Category:Gauntlets]]
| #default = [[Category:Armor]]
}}{{Armor/CargoStore
|name={{{title|}}}
|setname={{{Set|}}}
|type={{{Type|}}}
|weight={{{Weight|}}}
|sharpMk0={{{Mk0_Sharp|}}}
|bluntMk0={{{Mk0_Blunt|}}}
|technomancyMk0={{{Mk0_Technomancy|}}}
|sharpMk1={{{Mk1_Sharp|}}}
|bluntMk1={{{Mk1_Blunt|}}}
|technomancyMk1={{{Mk1_Technomancy|}}}
|sharpMk2={{{Mk2_Sharp|}}}
|bluntMk2={{{Mk2_Blunt|}}}
|technomancyMk2={{{Mk2_Technomancy|}}}
|sharpMk3={{{Mk3_Sharp|}}}
|bluntMk3={{{Mk3_Blunt|}}}
|technomancyMk3={{{Mk3_Technomancy|}}}
|sharpMk4={{{Mk4_Sharp|}}}
|bluntMk4={{{Mk4_Blunt|}}}
|technomancyMk4={{{Mk4_Technomancy|}}}
|sharpMk5={{{Mk5_Sharp|}}}
|bluntMk5={{{Mk5_Blunt|}}}
|technomancyMk5={{{Mk5_Technomancy|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
d407ded1b1e4484c38086c6409349aed6462786a
1190
1189
2025-08-22T09:40:40Z
Sharparam
284703
Fix misplaces braces
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Weight,Set,Passives
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| helmet = [[Helmet]]
| pauldrons = [[Pauldrons]]
| chestguard = [[Chestguard]]
| legguard = [[Legguard]]
| gauntlet = [[Gauntlet]]
| #default = {{{Type}}}
}}}}
|Set={{#if:{{{Set|}}}|{{#switch:{{lc:{{{Set}}}}}
| librarian = [[Librarian (armor set)|Librarian]]
| #default = [[{{{Set}}}]]
}}}}
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \!
| token = @@@@
| pattern = [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| helmet = [[Category:Helmets]]
| pauldrons = [[Category:Pauldrons]]
| chestguard = [[Category:Chestguards]]
| legguard = [[Category:Legguards]]
| gauntlet = [[Category:Gauntlets]]
| #default = [[Category:Armor]]
}}{{Armor/CargoStore
|name={{{title|}}}
|setname={{{Set|}}}
|type={{{Type|}}}
|weight={{{Weight|}}}
|sharpMk0={{{Mk0_Sharp|}}}
|bluntMk0={{{Mk0_Blunt|}}}
|technomancyMk0={{{Mk0_Technomancy|}}}
|sharpMk1={{{Mk1_Sharp|}}}
|bluntMk1={{{Mk1_Blunt|}}}
|technomancyMk1={{{Mk1_Technomancy|}}}
|sharpMk2={{{Mk2_Sharp|}}}
|bluntMk2={{{Mk2_Blunt|}}}
|technomancyMk2={{{Mk2_Technomancy|}}}
|sharpMk3={{{Mk3_Sharp|}}}
|bluntMk3={{{Mk3_Blunt|}}}
|technomancyMk3={{{Mk3_Technomancy|}}}
|sharpMk4={{{Mk4_Sharp|}}}
|bluntMk4={{{Mk4_Blunt|}}}
|technomancyMk4={{{Mk4_Technomancy|}}}
|sharpMk5={{{Mk5_Sharp|}}}
|bluntMk5={{{Mk5_Blunt|}}}
|technomancyMk5={{{Mk5_Technomancy|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
018b792ce369ad673cb81326c20732f36e2f4e23
Template:Infobox/Item
10
417
1191
892
2025-08-22T09:43:36Z
Sharparam
284703
Add support for materials
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind=item
| sep=,
| title={{{title|{{PAGENAME}}}}}
| image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=DescriptionSection
| DescriptionSection=Description
| DescriptionSection_label=Description
| Description_nolabel=yes
}}{{Main other|{{#switch:{{lc:{{{type|}}}}}
| essential = [[Category:Essential items]]
| upgrade = [[Category:Upgrade items]]
| material = [[Category:Materials]]
| #default = [[Category:Items]]
}}}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]</noinclude>
b03b79686bba1206934eab541c6768639949c1cc
Gingko Leaves
0
433
1192
629
2025-08-22T09:44:04Z
Sharparam
284703
Add infobox
wikitext
text/x-wiki
{{Infobox/Item
| type = material
| image = Gingko Leaves.png
}}
'''{{PAGENAME}}''' is a [[Materials|material]] found in {{BFF}} used in [[crafting]].
== Acquisition ==
Drops from several enemies in the game, as well as found on the ground in certain locations.
== Locations ==
{| class="wikitable"
! Amount !! Area !! Description !! Coordinates
|-
| 2 || [[Deluge]] || Found at the end of the platform before the bridge leading into the big rectangular structures with pillars. || {{coords|-4541|-1823|5552}}
|}
{{Navbox/Materials}}
[[Category:Materials]]
8533bbd6a3afd00d66170a3d89e01407aa5e92ed
1193
1192
2025-08-22T09:44:16Z
Sharparam
284703
Remove unnecessary manual category
wikitext
text/x-wiki
{{Infobox/Item
| type = material
| image = Gingko Leaves.png
}}
'''{{PAGENAME}}''' is a [[Materials|material]] found in {{BFF}} used in [[crafting]].
== Acquisition ==
Drops from several enemies in the game, as well as found on the ground in certain locations.
== Locations ==
{| class="wikitable"
! Amount !! Area !! Description !! Coordinates
|-
| 2 || [[Deluge]] || Found at the end of the platform before the bridge leading into the big rectangular structures with pillars. || {{coords|-4541|-1823|5552}}
|}
{{Navbox/Materials}}
e55300c158c70d2316f245ac6f97b1ac0490b1bd
File:Gingko Leaves.png
6
767
1194
2025-08-22T09:46:01Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/food__95_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/food__95_
}}
== Licensing ==
{{License|game}}
bb157c358311d9b1cdc8004bfa38c9b860dfa85b
Helmets
0
768
1195
2025-08-22T09:47:41Z
Sharparam
284703
Created page with "'''Helmets''' is armor worn on the head in {{BFF}}. {{Navbox/Armor}} [[Category:Helmets]]"
wikitext
text/x-wiki
'''Helmets''' is armor worn on the head in {{BFF}}.
{{Navbox/Armor}}
[[Category:Helmets]]
eb0f2e082e86b23efbaa2d5aa01598c47acf0423
Pauldrons
0
769
1196
2025-08-22T09:48:03Z
Sharparam
284703
Created page with "'''Pauldrons''' is armor worn on the shoulders in {{BFF}}. {{Navbox/Armor}} [[Category:Pauldrons]]"
wikitext
text/x-wiki
'''Pauldrons''' is armor worn on the shoulders in {{BFF}}.
{{Navbox/Armor}}
[[Category:Pauldrons]]
5fda269f272af445bff53a01c65c204739af1494
Category:Pauldrons
14
770
1197
2025-08-22T09:48:16Z
Sharparam
284703
Created page with "[[Category:Armor]]"
wikitext
text/x-wiki
[[Category:Armor]]
8dbf198b5dcaa87a18100850cc78880444b773ad
Chestguards
0
771
1198
2025-08-22T09:48:42Z
Sharparam
284703
Created page with "'''Chestguards''' is armor worn on the chest/torso in {{BFF}}. {{Navbox/Armor}} [[Category:Armor]]"
wikitext
text/x-wiki
'''Chestguards''' is armor worn on the chest/torso in {{BFF}}.
{{Navbox/Armor}}
[[Category:Armor]]
b5d8ee02000893e7cd4da78ac4eadde3635bda6e
Chestguards
0
771
1199
1198
2025-08-22T09:48:53Z
Sharparam
284703
Fix wrong category
wikitext
text/x-wiki
'''Chestguards''' is armor worn on the chest/torso in {{BFF}}.
{{Navbox/Armor}}
[[Category:Chestguards]]
ae282ffa9370d4795c6d2f312f06ec1d23474018
Legguards
0
772
1200
2025-08-22T09:49:20Z
Sharparam
284703
Created page with "'''Legguards''' is armor worn on the legs in {{BFF}}. {{Navbox/Armor}} [[Category:Legguards]]"
wikitext
text/x-wiki
'''Legguards''' is armor worn on the legs in {{BFF}}.
{{Navbox/Armor}}
[[Category:Legguards]]
b808da558f41bba9aa569af4ea8900afd620cdcd
Gauntlets
0
773
1201
2025-08-22T09:49:44Z
Sharparam
284703
Created page with "'''Gauntlets''' is armor worn on the hands in {{BFF}}. {{Navbox/Armor}} [[Category:Gauntlets]]"
wikitext
text/x-wiki
'''Gauntlets''' is armor worn on the hands in {{BFF}}.
{{Navbox/Armor}}
[[Category:Gauntlets]]
8905bf0ba5f2a4d97cd126387f0907c9b0c14b5e
Category:Gauntlets
14
774
1202
2025-08-22T09:49:56Z
Sharparam
284703
Created page with "[[Category:Armor]]"
wikitext
text/x-wiki
[[Category:Armor]]
8dbf198b5dcaa87a18100850cc78880444b773ad
Armor sets
0
775
1203
2025-08-22T09:51:28Z
Sharparam
284703
Created page with "'''Armor sets''' are collections of armor pieces that fit together and share common names. They do not give any additional or special stats or bonuses for wearing multiple from the same set. {{Navbox/Armor}} [[Category:Armor sets]]"
wikitext
text/x-wiki
'''Armor sets''' are collections of armor pieces that fit together and share common names.
They do not give any additional or special stats or bonuses for wearing multiple from the same set.
{{Navbox/Armor}}
[[Category:Armor sets]]
8010451533ab61de5a922f98b8d3e3a1448d8263
Category:Dual Wields
14
469
1204
887
2025-08-22T09:52:32Z
Sharparam
284703
Remove unnecessary grandparent category
wikitext
text/x-wiki
[[Category:Two-handed weapons]]
797f628182636dd7d53e09a5330ca3c8e98ffe59
Template:Navbox/Consumables
10
286
1205
330
2025-08-22T09:55:57Z
Sharparam
284703
Add [[Improved Diver's Lungs Concoction]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
| group2 = Fluids
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
* [[Restorative Fluid]]
| group3 = Concoctions
| list3 =
* [[Diver's Lungs Concoction]]
* [[Improved Diver's Lungs Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
* [[Concoction: Zealot's Tears]]
* [[Experience Concoction]]
* [[Mystery Concoction]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ac97c6dea70846027e525cba958dc4134b76f93e
1234
1205
2025-08-22T23:30:01Z
Sharparam
284703
Add links to fluids and concoctions
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
| group2 = [[Fluids]]
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
* [[Restorative Fluid]]
| group3 = [[Concoctions]]
| list3 =
* [[Diver's Lungs Concoction]]
* [[Improved Diver's Lungs Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Fluxshield Concoction]]
* [[Jaeger's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Dreadguard's Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Technomancer's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Forsaken Concoction]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Health Regen]]
* [[Concoction: Flux Regen]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Agility]]
* [[Concoction: Constitution]]
* [[Concoction: Intelligence]]
* [[Concoction: All Attributes]]
* [[Concoction: Zealot's Tears]]
* [[Experience Concoction]]
* [[Mystery Concoction]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
143073e2e8ef425ae4d6f6aa288ab2d4ee4c65c2
Improved Diver's Lungs Concoction
0
744
1206
1149
2025-08-22T09:56:38Z
Sharparam
284703
Add more information
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}.
== Recipe ==
Obtained by defeating the many-legged creature in [[Deluge]].
{{Navbox/Consumables}}
[[Category:Concoctions]]
6d7f860f0a4d166821ac9c9f45485fb606abbd78
1229
1206
2025-08-22T23:05:17Z
Sharparam
284703
Add infobox
wikitext
text/x-wiki
{{Infobox/Item
| image = Improved Diver's Lungs Concoction.png
| type = concoction
| Description = Increases maximum lung capacity by {{Duration|s=60|display=60 seconds}} worth of oxygen for {{Duration|s=600|display=600 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Consumables|consumable]] [[Concoctions|concoction]] in {{BFF}}.
== Recipe ==
Obtained by defeating the many-legged creature in [[Deluge]].
{{Navbox/Consumables}}
125ca95a7c845f9d99dc176f7ee336c9eff24a8e
File:Eris.png
6
776
1207
2025-08-22T21:44:24Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/Icon_CrystalBall
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/Icon_CrystalBall
}}
== Licensing ==
{{License|game}}
13791c85c8308f9808f3678aec68d1b5bc0eca95
Eris
0
495
1208
755
2025-08-22T21:45:13Z
Sharparam
284703
Add trivia about internal name
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Eris.png
| Type = Helmet
| Weight = Light
| Passives = Flux Efficiency
| Mk5_Sharp = 730
| Mk5_Blunt = 730
| Mk5_Technomancy = 939
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|2860|-4261|1423}}
Found in [[Uranopolis#Tower Complex|Uranopolis (Tower Complex)]]. Nestled between some round pillars.
== Trivia ==
* In the game files this helmet is called "Crystal Ball".
{{Navbox/Armor}}
982b1d7218dccd34133cfadfa4d01d6c42d78782
File:Crude Helmet.png
6
777
1209
2025-08-22T21:46:29Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/Icon_Respirator2
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/Icon_Respirator2
}}
== Licensing ==
{{License|game}}
7be523c7e5452991401a644cf5c2c1aeb23fd06d
Crude Helmet
0
489
1210
743
2025-08-22T21:47:01Z
Sharparam
284703
Add trivia about internal name
wikitext
text/x-wiki
{{Infobox/Armor
| image = Crude Helmet.png
| title = {{PAGENAME}}
| Type = Helmet
| Weight = Medium
| Mk2_Sharp = 516
| Mk2_Blunt = 600
| Mk2_Technomancy = 336
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] type of [[armor]] that can be found in {{BFF}}.
== Location ==
{{coords|-3538|-6027|5477}}
Found in [[Deluge|the Deluge]] area. After reaching the bottom of the big broken tower (where [[Folk Cape]] and [[Dust Sea|the Dust Sea]] can be found), continue right and follow the wall until you see a a corpse on a ledge holding the item.
== Trivia ==
* In the game files this helmet is called "Respirator 2".
{{Navbox/Armor}}
b994e21072eccbe0a11ea0897cfb76d018531488
File:Deserts Respirator Helmet.png
6
778
1211
2025-08-22T21:48:21Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/Icon_Respirator3
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/Icon_Respirator3
}}
== Licensing ==
{{License|game}}
943066b823dd97a699939deee1bd079a3458703f
Deserts Respirator Helmet
0
492
1212
749
2025-08-22T21:48:50Z
Sharparam
284703
Add trivia about internal name
wikitext
text/x-wiki
{{Infobox/Armor
| title = {{PAGENAME}}
| image = Deserts Respirator Helmet.png
| Type = helmet
| Weight = Medium
| Mk2_Sharp = 545
| Mk2_Blunt = 633
| Mk2_Technomancy = 336
}}
'''{{PAGENAME}}''' is a [[Helmets|helmet]] in {{BFF}}.
== Location ==
{{coords|1367|6630|-1395}}
Found in the [[Desert]]. Located on a corpse near the portal to [[Desert Mirage]].
== Trivia ==
* In the game files this helmet is called "Respirator 3".
{{Navbox/Armor}}
1e5cfba9361c3caecb26137e38805596bed59fd6
File:Citadel Warrior.png
6
779
1213
2025-08-22T22:01:46Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:Librarian.png
6
780
1214
2025-08-22T22:22:08Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:Sentinel.png
6
781
1215
2025-08-22T22:24:24Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:Vengeance.png
6
782
1216
2025-08-22T22:25:59Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Mobius Blade
0
666
1217
1027
2025-08-22T22:30:26Z
Sharparam
284703
Add item description
wikitext
text/x-wiki
{{Infobox/Item
| type = essential
| image = Mobius Blade.png
| Description = An enigmatic relic – a shimmering blade with immense and inexplicable power that operates in ways beyond conventional comprehension. The word Mobius is inscribed in its hilt.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Overview ==
The player can use the blade to kill themselves, allowing them to respawn at the [[homunculus]] they last saved their position at (or a [[Homunculus Mirage]]).
{{Navbox/Essential items}}
afd465d1ec5470c335393e767cb4fc666b131fe2
File:Perk Essence.png
6
783
1218
2025-08-22T22:32:09Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_21
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_21
}}
== Licensing ==
{{License|game}}
2e7311f76def2a759f1e8023d70c2d23a892e4eb
File:Unstable Perk Essence.png
6
784
1219
2025-08-22T22:32:47Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_24
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_24
}}
== Licensing ==
{{License|game}}
8e91bbce8b005be8e383d57d306ccd2b46305482
File:Plagued Blood.png
6
785
1220
2025-08-22T22:34:39Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_50
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_50
}}
== Licensing ==
{{License|game}}
cec79d0946a981f402df171aee3c18f864c078ec
Anomalous Fragment
0
426
1221
615
2025-08-22T22:35:59Z
Sharparam
284703
Set type in infobox and add navbox
wikitext
text/x-wiki
{{Infobox/Item
| type = essential
| title = {{PAGENAME}}
| image = Anomalous Fragment.png
| Description = [[The Handler|Handler]] may convert it to a more useful form.
}}
'''{{PAGENAME}}''' is an [[Essential items|essential item]] in {{BFF}}.
== Acquisition ==
Drops from [[bosses]] in [[NG+]].
== Usage ==
Used to manufacture [[Greater Anomalous Crystal|Greater Anomalous Crystals]] at [[The Handler]].
{{Navbox/Essential items}}
1d2150fe8c156d69c0f502eab860d67c2c37ee99
Template:Navbox/Essential items
10
663
1222
1023
2025-08-22T22:36:27Z
Sharparam
284703
Add [[Anomalous Fragment]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Essential items
| title = [[Essential items]]
| list1 =
* [[Ability Splinter]]
* [[Anomalous Fragment]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group1.1 = [[Upgrade items|Upgrade]]
| list1.1 =
* [[Upgrade Splinter]]
* [[Upgrade Module]]
}}<noinclude>{{Documentation}}</noinclude>
b6acc68ad0aba7b49cdce6e0674bae9ec26fe22d
File:Anomalous Fragment.png
6
786
1223
2025-08-22T22:37:10Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_11
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRunes/256x256/ClassicRunes_11
}}
== Licensing ==
{{License|game}}
e783567ca742b544e6f91ab052f3d7ea549145b6
Category:Concoctions
14
787
1224
2025-08-22T22:38:29Z
Sharparam
284703
Created page with "[[Category:Consumables]]"
wikitext
text/x-wiki
[[Category:Consumables]]
193ccd7fd91966b7687713ee56f8a8ec4b51e614
Category:Consumables
14
788
1225
2025-08-22T22:38:43Z
Sharparam
284703
Created page with "[[Category:Items]]"
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Template:Infobox/Item
10
417
1226
1191
2025-08-22T22:40:15Z
Sharparam
284703
Add support for consumables, fluids, and concoctions
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind=item
| sep=,
| title={{{title|{{PAGENAME}}}}}
| image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=DescriptionSection
| DescriptionSection=Description
| DescriptionSection_label=Description
| Description_nolabel=yes
}}{{Main other|{{#switch:{{lc:{{{type|}}}}}
| essential = [[Category:Essential items]]
| upgrade = [[Category:Upgrade items]]
| material = [[Category:Materials]]
| consumable = [[Category:Consumables]]
| fluid = [[Category:Fluids]]
| concoction = [[Category:Concoctions]]
| #default = [[Category:Items]]
}}}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]</noinclude>
893d7291a9f8b061cc61e1758dcd1198d548dc65
Template:Infobox/Item/doc
10
464
1227
693
2025-08-22T22:56:16Z
Sharparam
284703
Add TemplateData
wikitext
text/x-wiki
== TemplateData ==
<templatedata>
{
"description": "Infobox used for items of various kinds that don't have a specialized infobox.",
"format": "block",
"params": {
"title": {
"label": "Title",
"description": "Title/name of the item. If not given it will use the name of the page the infobox is used on (usually results in the desired name).",
"type": "line",
"required": false,
"default": "{{PAGENAME}}",
"example": "Health Potion"
},
"image": {
"label": "Image",
"description": "Game image for the item.",
"type": "wiki-file-name",
"required": true,
"example": "Health Potion.png"
},
"type": {
"label": "Type",
"description": "Item type. Supported values are 'consumable', 'essential', 'upgrade', 'material', 'fluid', and 'concoction'. Other values or not specifying it makes the infobox fallback to treating it as a generic item. Even for generic items, it is recommended to supply this parameter and simply specify it as 'item'.",
"type": "line",
"required": false,
"suggested": true,
"default": "item",
"example": "consumable",
"suggestedvalues": [
"item",
"concoction",
"consumable",
"essential",
"fluid",
"material",
"upgrade"
]
},
"Description": {
"label": "Description",
"description": "In-game description of the item, if available. Do not use this field for your own description of an item, that belongs in the article body instead.",
"type": "string",
"required": false,
"example": "Restores a portion of your health."
}
}
}
</templatedata>
== Examples ==
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| type = consumable
| Description = This item will do something fancy when you use it!
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| type = consumable
| Description = This item will do something fancy when you use it!
}}
</syntaxhighlight>
ca8b0fcbede569135444bbac9669e398fa06f6a2
Template:Duration/doc
10
789
1228
2025-08-22T23:02:45Z
Sharparam
284703
Created page with "== Examples == * <syntaxhighlight lang="wikitext" inline>{{Duration|3:30}}</syntaxhighlight> → {{Duration|3:30}} * <syntaxhighlight lang="wikitext" inline>{{Duration|h=1|m=2|s=3}}</syntaxhighlight> → {{Duration|h=1|m=2|s=3}} * <syntaxhighlight lang="wikitext" inline>{{Duration|3|2|1}}</syntaxhighlight> → {{Duration|3|2|1}} * <syntaxhighlight lang="wikitext" inline>{{Duration|3:30:00|display=A really long time!}}</syntaxhighlight> → {{Duration|3:30:00..."
wikitext
text/x-wiki
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Duration|3:30}}</syntaxhighlight> → {{Duration|3:30}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|h=1|m=2|s=3}}</syntaxhighlight> → {{Duration|h=1|m=2|s=3}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|3|2|1}}</syntaxhighlight> → {{Duration|3|2|1}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|3:30:00|display=A really long time!}}</syntaxhighlight> → {{Duration|3:30:00|display=A really long time!}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|PT3H30M12S}}</syntaxhighlight> → {{Duration|PT3H30M12S}}
d920850f2db2a205afa2cefb501d9231c694b609
Concoctions
0
790
1230
2025-08-22T23:07:28Z
Sharparam
284703
Created page with "'''Concoctions''' are a type of [[Consumables|consumable]] in {{BFF}}. While [[fluids]] give instant restoration or short duration buffs, concoctions tend to give buffs like stat increases for a longer period of time. {{Navbox/Consumables}} [[Category:Concoctions]]"
wikitext
text/x-wiki
'''Concoctions''' are a type of [[Consumables|consumable]] in {{BFF}}. While [[fluids]] give instant restoration or short duration buffs, concoctions tend to give buffs like stat increases for a longer period of time.
{{Navbox/Consumables}}
[[Category:Concoctions]]
4f232b80e8f16735421b1daa0047d19dfd388747
File:Improved Diver's Lungs Concoction.png
6
791
1231
2025-08-22T23:08:14Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_56
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_56
}}
== Licensing ==
{{License|game}}
b1b2ea2d8e30048616cf00a2afa76912557f63b8
Module:Duration
828
412
1232
585
2025-08-22T23:18:53Z
Sharparam
284703
Improve parsing of duration
Scribunto
text/plain
---Duration module
---@module DurationModule
---@alias p
local getArgs = require('Module:Arguments').getArgs
local ARG_OPTS = {
wrappers = {
"Template:Duration"
}
}
---@class Duration
---@field h
---@field m
---@field s
---@type Duration
local ZERO = { h = 0, m = 0, s = 0 }
---@type int[][]
local LOOKUP = {
[1] = { 0, 0, 1 },
[2] = { 0, 1, 2 },
[3] = { 1, 2, 3 }
}
local p = {}
---@param args any
---@return Duration
local function parseDuration(args)
local h = tonumber(args.h or args[1])
local m = tonumber(args.m or args[2])
local s = tonumber(args.s or args[3])
if h or m or s then
h = h or 0
m = m or 0
s = s or 0
else
local input = args[1]
if not input or input == "" then return ZERO end
local parts = {}
for part in string.gmatch(input, "%d+") do
parts[#parts + 1] = tonumber(part) or 0
end
local size = #parts
h = parts[LOOKUP[size][1]] or 0
m = parts[LOOKUP[size][2]] or 0
s = parts[LOOKUP[size][3]] or 0
end
local seconds = h * 60 * 60 + m * 60 + s
local hours = math.floor(total_seconds / 60 / 60)
seconds = seconds - hours * 60 * 60
local minutes = math.floor(total_seconds / 60)
seconds = seconds - minutes * 60
return {
h = hours,
m = minutes,
s = seconds
} --[[@as Duration]]
end
---@param duration Duration
---@return string
local function toisostring(duration)
return string.format("PT%dH%dM%dS", duration.h, duration.m, duration.s)
end
---@param duration Duration
---@return string
local function todisplaystring(duration)
if duration.h > 0 then
return string.format("%02d:%02d:%02d", duration.h, duration.m, duration.s)
end
return string.format("%02d:%02d", duration.m, duration.s)
end
---@param frame any
---@return any
function p.main(frame)
local args = getArgs(frame, ARG_OPTS)
return p._main(args, function(s) return frame:preprocess(s) end)
end
function p._main(args, preprocess)
preprocess = preprocess or function(s) return s end
local duration = parseDuration(args)
local iso = toisostring(duration)
local display
local is_custom_display = false
if args.display then
display = preprocess(args.display)
is_custom_display = true
else
display = todisplaystring(duration)
end
local elem = mw.html.create('time')
:attr('datetime', iso)
:addClass('duration')
:wikitext(display)
if is_custom_display then
elem:attr('title', todisplaystring(duration))
:addClass('dotted')
end
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles', args = { src = 'Module:Duration/styles.css' }
} .. tostring(elem)
end
return p
03ec8d76a08d2df423bef69d7af5c53b74fe7036
1233
1232
2025-08-22T23:21:26Z
Sharparam
284703
Fix typo
Scribunto
text/plain
---Duration module
---@module DurationModule
---@alias p
local getArgs = require('Module:Arguments').getArgs
local ARG_OPTS = {
wrappers = {
"Template:Duration"
}
}
---@class Duration
---@field h
---@field m
---@field s
---@type Duration
local ZERO = { h = 0, m = 0, s = 0 }
---@type int[][]
local LOOKUP = {
[1] = { 0, 0, 1 },
[2] = { 0, 1, 2 },
[3] = { 1, 2, 3 }
}
local p = {}
---@param args any
---@return Duration
local function parseDuration(args)
local h = tonumber(args.h or args[1])
local m = tonumber(args.m or args[2])
local s = tonumber(args.s or args[3])
if h or m or s then
h = h or 0
m = m or 0
s = s or 0
else
local input = args[1]
if not input or input == "" then return ZERO end
local parts = {}
for part in string.gmatch(input, "%d+") do
parts[#parts + 1] = tonumber(part) or 0
end
local size = #parts
h = parts[LOOKUP[size][1]] or 0
m = parts[LOOKUP[size][2]] or 0
s = parts[LOOKUP[size][3]] or 0
end
local seconds = h * 60 * 60 + m * 60 + s
local hours = math.floor(seconds / 60 / 60)
seconds = seconds - hours * 60 * 60
local minutes = math.floor(seconds / 60)
seconds = seconds - minutes * 60
return {
h = hours,
m = minutes,
s = seconds
} --[[@as Duration]]
end
---@param duration Duration
---@return string
local function toisostring(duration)
return string.format("PT%dH%dM%dS", duration.h, duration.m, duration.s)
end
---@param duration Duration
---@return string
local function todisplaystring(duration)
if duration.h > 0 then
return string.format("%02d:%02d:%02d", duration.h, duration.m, duration.s)
end
return string.format("%02d:%02d", duration.m, duration.s)
end
---@param frame any
---@return any
function p.main(frame)
local args = getArgs(frame, ARG_OPTS)
return p._main(args, function(s) return frame:preprocess(s) end)
end
function p._main(args, preprocess)
preprocess = preprocess or function(s) return s end
local duration = parseDuration(args)
local iso = toisostring(duration)
local display
local is_custom_display = false
if args.display then
display = preprocess(args.display)
is_custom_display = true
else
display = todisplaystring(duration)
end
local elem = mw.html.create('time')
:attr('datetime', iso)
:addClass('duration')
:wikitext(display)
if is_custom_display then
elem:attr('title', todisplaystring(duration))
:addClass('dotted')
end
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles', args = { src = 'Module:Duration/styles.css' }
} .. tostring(elem)
end
return p
1e05aa6ebf1e3a52baee275fe149a5e5b80d51c5
Fluids
0
792
1235
2025-08-22T23:31:32Z
Sharparam
284703
Created page with "'''Fluids''' are a type of [[Consumables|consumable]] in {{BFF}}. They typically give instant restoration of resources like [[health]] and [[flux]], or a short buff that restores it over time, unlike [[concoctions]] that tend to give longer buffs to stats. {{Navbox/Consumables}}"
wikitext
text/x-wiki
'''Fluids''' are a type of [[Consumables|consumable]] in {{BFF}}. They typically give instant restoration of resources like [[health]] and [[flux]], or a short buff that restores it over time, unlike [[concoctions]] that tend to give longer buffs to stats.
{{Navbox/Consumables}}
f032454331c9c43545909d07ee277b137f8372e1
1236
1235
2025-08-22T23:31:42Z
Sharparam
284703
Add category
wikitext
text/x-wiki
'''Fluids''' are a type of [[Consumables|consumable]] in {{BFF}}. They typically give instant restoration of resources like [[health]] and [[flux]], or a short buff that restores it over time, unlike [[concoctions]] that tend to give longer buffs to stats.
{{Navbox/Consumables}}
[[Category:Fluids]]
88b1f660d7f977146d02c2dc2713d8f2d220f19f
Category:Fluids
14
793
1237
2025-08-22T23:31:56Z
Sharparam
284703
Created page with "[[Category:Consumables]]"
wikitext
text/x-wiki
[[Category:Consumables]]
193ccd7fd91966b7687713ee56f8a8ec4b51e614
Materials
0
431
1238
625
2025-08-22T23:36:27Z
Sharparam
284703
Add acquisition notes
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] used to [[Crafting|craft]] or [[Manufacturing|manufacture]] other items.
== Acquisition ==
Materials are dropped by enemies or found on the ground. [[Essence|Essences]] can also be extracted from [[Anomalous Crystals]], although it requires destroying the crystal.
{{Navbox/Materials}}
54925fc2f73f55d978246de626db57b71ee98da4
1243
1238
2025-08-22T23:46:12Z
Sharparam
284703
Add info on UI quirks
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] used to [[Crafting|craft]] or [[Manufacturing|manufacture]] other items.
== Overview ==
After collecting more than 999 of a material, the inventory will simply show the count as "999+". To see the actual amount of the material, go to the crafting tab and look at an item that uses it in its recipe.
== Acquisition ==
Materials are dropped by enemies or found on the ground. [[Essence|Essences]] can also be extracted from [[Anomalous Crystals]], although it requires destroying the crystal.
{{Navbox/Materials}}
16c03274cbdefa879852d2add32a15681dc36535
Essence
0
794
1239
2025-08-22T23:40:05Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Essence.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. == Acquisition == Can be extracted from [[Anomalous crystals]], destroying the crystal in the process. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Essence.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
== Acquisition ==
Can be extracted from [[Anomalous crystals]], destroying the crystal in the process.
{{Navbox/Materials}}
89adde888d87bb8704953166b5a42b3da2da95c5
File:Essence.png
6
795
1240
2025-08-22T23:40:45Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/lantern__10_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/lantern__10_
}}
== Licensing ==
{{License|game}}
1822b1d8229259ef1d6c5275b994fad589558960
Sludge
0
796
1241
2025-08-22T23:43:52Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Sludge.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. == Acquisition == Dropped by enemies and found on the ground in certain locations. Compared to other materials, sludge is very plentiful and a player is likely to have thousands of it while only having dozens or hundreds of other materials. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Sludge.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
== Acquisition ==
Dropped by enemies and found on the ground in certain locations.
Compared to other materials, sludge is very plentiful and a player is likely to have thousands of it while only having dozens or hundreds of other materials.
{{Navbox/Materials}}
db6f64f0e318a3fef7e2730138aac402316df24c
File:Sludge.png
6
797
1242
2025-08-22T23:44:24Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/goldpile__3_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/goldpile__3_
}}
== Licensing ==
{{License|game}}
9ea5dcd2eae75a87ae6111f20d1f12be6504c498
Fractal Fungus
0
798
1244
2025-08-23T00:38:08Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Fractal Fungus.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Fractal Fungus.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
{{Navbox/Materials}}
605f3cf626e7517db3043a7f06c86c76de08e1f9
Gravicle Dust
0
799
1245
2025-08-23T00:38:27Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Gravicle Dust.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Gravicle Dust.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
{{Navbox/Materials}}
860212f45dfe29e748e9794188e92c013a052bdd
Machinite
0
800
1246
2025-08-23T00:38:38Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Machinite.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Machinite.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
{{Navbox/Materials}}
e1d39616d0055f9ba158fb4e237c2c665ae90cc6
Neurilium
0
801
1247
2025-08-23T00:38:54Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Neurilium.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Neurilium.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
{{Navbox/Materials}}
e2a91027e9404b8aef5aae8792babcd1c717437c
Rustvine
0
802
1248
2025-08-23T00:39:05Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Rustvine.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Rustvine.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
{{Navbox/Materials}}
e4bb7f054f0694d1bd88a934d6eab29383826649
Spectral Ash
0
803
1249
2025-08-23T00:39:15Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Spectral Ash.png | type = material }} '''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}. {{Navbox/Materials}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Spectral Ash.png
| type = material
}}
'''{{PAGENAME}}''' is a [[crafting]] [[Materials|material]] in {{BFF}}.
{{Navbox/Materials}}
79ee0d1ee2797a3b441ed037f13a4850be4c42e0
File:Gravicle Dust.png
6
804
1250
2025-08-23T00:40:32Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ingredient__20_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ingredient__20_
}}
== Licensing ==
{{License|game}}
d1957f752190c71a990c31b1cd3d067caddef177
File:Machinite.png
6
805
1251
2025-08-23T00:41:34Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ore__15_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ore__15_
}}
== Licensing ==
{{License|game}}
c2c900b1ef60bea290f7405aefd7e3bb314ca512
File:Neurilium.png
6
806
1252
2025-08-23T00:42:04Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ingredient__193_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ingredient__193_
}}
== Licensing ==
{{License|game}}
37cc40dd2d2e96e3ec7f3366ec45bc45962f3ac9
File:Rustvine.png
6
807
1253
2025-08-23T00:42:31Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/food__99_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/food__99_
}}
== Licensing ==
{{License|game}}
a36bbaaa71585eaf4240caf83773d35bc7a59887
File:Spectral Ash.png
6
808
1254
2025-08-23T00:43:02Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ingredient__74_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ingredient__74_
}}
== Licensing ==
{{License|game}}
59d0e0e8fc788687ecc5e368dd6640fe050d0685
File:Fractal Fungus.png
6
809
1255
2025-08-23T00:43:29Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ingredient__4_
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ingredient__4_
}}
== Licensing ==
{{License|game}}
a5301c278a338e04b74203c2b2d0448ab3e8c3f0
Template:Navbox/Consumables
10
286
1256
1234
2025-08-23T00:52:44Z
Sharparam
284703
Add more consumables
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Asylum Brew]]
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
* [[Piercing Arrow Pack]]
| group2 = [[Fluids]]
| list2 =
* [[Greater Ionization Fluid]]
* [[Greater Regenerative Fluid]]
* [[Greater Restorative Fluid]]
* [[Ionization Fluid]]
* [[Lesser Ionization Fluid]]
* [[Lesser Restorative Fluid]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
* [[Restorative Fluid]]
| group3 = [[Concoctions]]
| list3 =
* [[Diver's Lungs Concoction]]
* [[Dreadguard's Concoction]]
* [[Experience Concoction]]
* [[Fluxshield Concoction]]
* [[Forsaken Concoction]]
* [[Greater Dreadguard's Concoction]]
* [[Greater Jaeger's Concoction]]
* [[Greater Technomancer's Concoction]]
* [[Improved Diver's Lungs Concoction]]
* [[Indestructible Concoction]]
* [[Jaeger's Concoction]]
* [[Mystery Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Technomancer's Concoction]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Agility]]
* [[Concoction: All Attributes]]
* [[Concoction: Berserker's Tenacity]]
* [[Concoction: Constitution]]
* [[Concoction: Flux Regen]]
* [[Concoction: Health Regen]]
* [[Concoction: Intelligence]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Powerful Immune System]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Zealot's Tears]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
0cf54c50606d4658229eeca534b614c602feb4ac
Template:Navbox/Items
10
285
1257
1025
2025-08-23T00:54:59Z
Sharparam
284703
Add ammunition
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Items
| title = [[Items]]
| group1 = [[Essential items|Essential]]
| list1 = {{Navbox/Essential items|child}}
| group2 = [[Ammunition]]
| list2 = {{Navbox/Ammunition|child}}
| group3 = [[Anomalous crystals]]
| list3 = {{Navbox/Anomalous crystals|child}}
| group4 = [[Consumables]]
| list4 = {{Navbox/Consumables|child}}
| group5 = [[Equipment]]
| list5 = {{Navbox/Equipment|child}}
| group6 = [[Materials]]
| list6 = {{Navbox/Materials|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
5153392b72f92ebc1a99e6f1772e7a128a25784e
Template:Navbox/Ammunition
10
810
1258
2025-08-23T00:57:06Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | template = Navbox/Ammunition | title = [[Ammunition]] | list1 = * [[Metal Arrows]] * [[Piercing Arrow]] * [[Shock Arrows]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Ammunition
| title = [[Ammunition]]
| list1 =
* [[Metal Arrows]]
* [[Piercing Arrow]]
* [[Shock Arrows]]
}}<noinclude>{{Documentation}}</noinclude>
f87d2ad23704598b8ed6727d82e1a6f74f671cf4
Template:Navbox/Ammunition/doc
10
811
1259
2025-08-23T00:57:40Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
a072d936de3f697ea20b212186fc4bf85674e635
Template:Navbox
10
45
1260
53
2025-08-23T00:59:19Z
Sharparam
284703
Protected "[[Template:Navbox]]": Widely transcluded: Basic template used by all navbox templates. Edit the relevant specific navbox template instead. (Also, this simply calls the Lua module so there's little reason to edit this basic template.) ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
<includeonly>{{#invoke:Navbox|main}}</includeonly><noinclude>[[Category:Navigation templates]] {{documentation}}</noinclude>
11355a4514de8aa6c0ae686240591d267101c58c
Template:Navbox/Essential items
10
663
1261
1222
2025-08-23T01:00:26Z
Sharparam
284703
Add [[Broken Arrow]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Essential items
| title = [[Essential items]]
| list1 =
* [[Ability Splinter]]
* [[Anomalous Fragment]]
* [[Broken Arrow]]
* [[Handler Echo]]
* [[Homunculus Mirage]] ([[Homunculus Mirage Husk|Husk]])
* [[Mobius Blade]]
* [[Old Key]]
* [[Perk Essence]] ([[Unstable Perk Essence|Unstable]])
* [[Plagued Blood]]
* [[Scanner]]
| group1.1 = [[Upgrade items|Upgrade]]
| list1.1 =
* [[Upgrade Splinter]]
* [[Upgrade Module]]
}}<noinclude>{{Documentation}}</noinclude>
a0b32a5211b92c2883d548badf73e8b9a242bd79
Broken Arrow
0
812
1262
2025-08-23T01:02:40Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Broken Arrow.png | type = essential | Description = An even more common kind of arrow – a broken one. }} '''{{PAGENAME}}''' is an [[Items|item]] in {{BFF}}. Its only purpose is to be crafted into [[Metal Arrows]], at a rate of three broken arrows for one metal arrow. {{Navbox/Essential items}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Broken Arrow.png
| type = essential
| Description = An even more common kind of arrow – a broken one.
}}
'''{{PAGENAME}}''' is an [[Items|item]] in {{BFF}}. Its only purpose is to be crafted into [[Metal Arrows]], at a rate of three broken arrows for one metal arrow.
{{Navbox/Essential items}}
e31b3d8e33a64fbf4ee756f13613a02441313b11
File:Broken Arrow.png
6
813
1263
2025-08-23T01:03:05Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/BrokenArrow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/BrokenArrow
}}
== Licensing ==
{{License|game}}
2d63b0638f2ac03b835bb73d15bc884a05b8a2d5
Ammunition
0
814
1264
2025-08-23T01:04:47Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' are items that can be show with [[longbows]]. {{Navbox/Ammunition}} [[Category:Ammunition]]"
wikitext
text/x-wiki
'''{{PAGENAME}}''' are items that can be show with [[longbows]].
{{Navbox/Ammunition}}
[[Category:Ammunition]]
bcca4dcdcefb3efa4007fae163ea1d5dcf5596dc
Category:Ammunition
14
815
1265
2025-08-23T01:04:58Z
Sharparam
284703
Created page with "[[Category:Items]]"
wikitext
text/x-wiki
[[Category:Items]]
8bd3beebb2826830a9eade77bf73f03d8286ea27
Metal Arrows
0
816
1266
2025-08-23T01:06:39Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Metal Arrows.png | type = ammunition | Description = A common and replaceable projectile. }} '''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}. {{Navbox/Ammunition}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Metal Arrows.png
| type = ammunition
| Description = A common and replaceable projectile.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
{{Navbox/Ammunition}}
cbe6a8a057aa88f1bce95efa8dd6063b69c77e33
1272
1266
2025-08-23T01:14:18Z
Sharparam
284703
Add navbox for longbows
wikitext
text/x-wiki
{{Infobox/Item
| image = Metal Arrows.png
| type = ammunition
| Description = A common and replaceable projectile.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
{{Navbox/Ammunition}}
{{Navbox/Longbows|state=collapsed}}
3c57de54bbddc8e4e2c1313ff2f80c6ed10435f3
File:Metal Arrows.png
6
817
1267
2025-08-23T01:07:03Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/Basicarrow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/Basicarrow
}}
== Licensing ==
{{License|game}}
2280dbdb249a77507d41195c58c5bb0d58a94202
Template:Infobox/Item
10
417
1268
1226
2025-08-23T01:07:47Z
Sharparam
284703
Add support for [[Ammunition]]
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind=item
| sep=,
| title={{{title|{{PAGENAME}}}}}
| image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=DescriptionSection
| DescriptionSection=Description
| DescriptionSection_label=Description
| Description_nolabel=yes
}}{{Main other|{{#switch:{{lc:{{{type|}}}}}
| ammo
| ammunition = [[Category:Ammunition]]
| essential = [[Category:Essential items]]
| upgrade = [[Category:Upgrade items]]
| material = [[Category:Materials]]
| consumable = [[Category:Consumables]]
| fluid = [[Category:Fluids]]
| concoction = [[Category:Concoctions]]
| #default = [[Category:Items]]
}}}}</includeonly><noinclude>
{{Documentation}}
[[Category:Infobox templates]]</noinclude>
15e673304251e5c68c7123d77ca24910b676c118
Template:Infobox/Item/doc
10
464
1269
1227
2025-08-23T01:08:16Z
Sharparam
284703
Add doc for ammunition type
wikitext
text/x-wiki
== TemplateData ==
<templatedata>
{
"description": "Infobox used for items of various kinds that don't have a specialized infobox.",
"format": "block",
"params": {
"title": {
"label": "Title",
"description": "Title/name of the item. If not given it will use the name of the page the infobox is used on (usually results in the desired name).",
"type": "line",
"required": false,
"default": "{{PAGENAME}}",
"example": "Health Potion"
},
"image": {
"label": "Image",
"description": "Game image for the item.",
"type": "wiki-file-name",
"required": true,
"example": "Health Potion.png"
},
"type": {
"label": "Type",
"description": "Item type. Supported values are 'ammunition', 'consumable', 'essential', 'upgrade', 'material', 'fluid', and 'concoction'. Other values or not specifying it makes the infobox fallback to treating it as a generic item. Even for generic items, it is recommended to supply this parameter and simply specify it as 'item'.",
"type": "line",
"required": false,
"suggested": true,
"default": "item",
"example": "consumable",
"suggestedvalues": [
"item",
"ammunition",
"concoction",
"consumable",
"essential",
"fluid",
"material",
"upgrade"
]
},
"Description": {
"label": "Description",
"description": "In-game description of the item, if available. Do not use this field for your own description of an item, that belongs in the article body instead.",
"type": "string",
"required": false,
"example": "Restores a portion of your health."
}
}
}
</templatedata>
== Examples ==
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| type = consumable
| Description = This item will do something fancy when you use it!
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Item
| image = Fancy item.png
| title = Fancy item
| type = consumable
| Description = This item will do something fancy when you use it!
}}
</syntaxhighlight>
b7072508bd1ef0424021e2fd29e396de42abd452
Template:Navbox/Longbows
10
818
1270
2025-08-23T01:13:03Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | state = {{{state|}}} | template = Navbox/Longbows | title = [[Longbows]] | list1 = * [[Arcane Bow]] * [[Longbow]] * [[Taskmaster]] * [[Winged bow]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Longbows
| title = [[Longbows]]
| list1 =
* [[Arcane Bow]]
* [[Longbow]]
* [[Taskmaster]]
* [[Winged bow]]
}}<noinclude>{{Documentation}}</noinclude>
a52bb6aa077c6e7d02ee5f21a9d706b0ad698d7e
Template:Navbox/Longbows/doc
10
819
1271
2025-08-23T01:13:35Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
a072d936de3f697ea20b212186fc4bf85674e635
Template:Navbox/Ranged weapons
10
820
1273
2025-08-23T01:17:39Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | state = {{{state|}}} | group1 = [[Longbows]] | list1 = {{Navbox/Longbows|child}} | group2 = [[Staves]] | list2 = * [[Asklepios]] * [[Blessed Crosier]] * [[Evolved Staff]] * [[Mechanomad Staff]] * [[Vermillion Staff]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| group1 = [[Longbows]]
| list1 = {{Navbox/Longbows|child}}
| group2 = [[Staves]]
| list2 =
* [[Asklepios]]
* [[Blessed Crosier]]
* [[Evolved Staff]]
* [[Mechanomad Staff]]
* [[Vermillion Staff]]
}}<noinclude>{{Documentation}}</noinclude>
6173db7c4376edf846d8951786b78f364a3ebc83
1274
1273
2025-08-23T01:18:17Z
Sharparam
284703
Fix missing params
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Ranged weapons
| title = [[Ranged weapons]]
| group1 = [[Longbows]]
| list1 = {{Navbox/Longbows|child}}
| group2 = [[Staves]]
| list2 =
* [[Asklepios]]
* [[Blessed Crosier]]
* [[Evolved Staff]]
* [[Mechanomad Staff]]
* [[Vermillion Staff]]
}}<noinclude>{{Documentation}}</noinclude>
a00bcfa757ece76ed674698fb0404ad2f82a5788
Template:Navbox/Weapons
10
438
1275
1059
2025-08-23T01:18:56Z
Sharparam
284703
Switch to child navbox for ranged weapons
wikitext
text/x-wiki
<!-- Weapons must be listed in alphabetical order! -->
{{Navbox
| {{{1|}}}
| template = Navbox/Weapons
| title = [[Weapons]]
| group1 = [[One-handed weapons|One-handed]]
| list1 =
* [[Arming Sword]]
* [[Industrial Axe]]
* [[Industrial Mace]]
* [[Iron Pipe]]
* [[Longsword]]
* [[Machinist's Hammer]]
* [[Morning Star]]
* [[Paladin Mace]]
* [[Ratagan Sabre]]
* [[Scimitar]]
* [[Soul Breaker]]
* [[Tire Iron]]
* [[Torch]]
* [[Woodchopper]]
| group2 = [[Two-handed weapons|Two-handed]]
| list2 =
* [[Anastasia]]
* [[Claymore]]
* [[Crescent Axe]]
* [[Faussart]]
* [[Halberd]]
* [[Mechanical Tenderizer]]
* [[Nodachi]]
* [[Royal Claymore]]
* [[Rusty Claymore]]
* [[Solaris]]
* [[Soul Reaper]]
* [[Valtiel]]
| group2.1 = [[Dual Wields]]
| list2.1 =
* [[Blades of Atropos]]
* [[Daggers]]
* [[Kamas]]
* [[Katanas]]
* [[Khopeshs]]
* [[Lacerators]]
| group2.2 = [[Twinblades]]
| list2.2 =
* [[Twinblade]]
| group2.3 = [[Greatweapons]]
| list2.3 =
* [[Armor Buster]]
* [[Divine Greataxe]]
* [[Eviscerator]]
* [[Greathammer]]
| group3 = [[Ranged weapons|Ranged]]
| list3 = {{Navbox/Ranged weapons|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
cb065e4fb7e8abbaa07e27234536a0d85b22d837
Template:Navbox/Ranged weapons/doc
10
821
1276
2025-08-23T01:19:38Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
a072d936de3f697ea20b212186fc4bf85674e635
Piercing Arrow
0
822
1277
2025-08-23T01:20:47Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Piercing Arrow.png | type = ammunition | Description = A projectile that ignores up to 2000 armor rating. }} '''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}. {{Navbox/Ammunition}} {{Navbox/Longbows|state=collapsed}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Piercing Arrow.png
| type = ammunition
| Description = A projectile that ignores up to 2000 armor rating.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
{{Navbox/Ammunition}}
{{Navbox/Longbows|state=collapsed}}
ee55b68eda821ca46afd9433e29d4ca3626e7134
File:Piercing Arrow.png
6
823
1278
2025-08-23T01:21:22Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/PiercingArrow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/PiercingArrow
}}
== Licensing ==
{{License|game}}
d15e7e54bdb589d6cf5e48b2ef48acb409190de0
Shock Arrows
0
824
1279
2025-08-23T01:22:53Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Shock Arrows.png | type = ammunition | Description = A projectile that stuns most enemies for {{Duration|s=7|display=7 seconds}}. }} '''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}. {{Navbox/Ammunition}} {{Navbox/Longbows|state=collapsed}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Shock Arrows.png
| type = ammunition
| Description = A projectile that stuns most enemies for {{Duration|s=7|display=7 seconds}}.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
{{Navbox/Ammunition}}
{{Navbox/Longbows|state=collapsed}}
d236e07c75607e37cacee19e8b7681057d8e4d11
File:Shock Arrows.png
6
825
1280
2025-08-23T01:23:19Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ShockArrow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ShockArrow
}}
== Licensing ==
{{License|game}}
c34d8433913650912573eb234b0b0dc8a2c47818
Template:Hlist
10
826
1282
1281
2025-08-23T01:31:50Z
Sharparam
284703
1 revision imported
wikitext
text/x-wiki
{{<includeonly>safesubst:</includeonly>#invoke:list|horizontal}}<noinclude>
{{documentation}}
<!-- Categories go on the /doc subpage, and interwikis go on Wikidata. -->
</noinclude>
9e3824c2e3c0e0dbef2f37556ac0b994987fecf9
Template:Hlist/styles.css
10
827
1284
1283
2025-08-23T01:31:51Z
Sharparam
284703
1 revision imported
sanitized-css
text/css
/* {{pp-protected|reason=match parent|small=yes}} */
/*
* hlist styles are defined in core and Minerva and differ in Minerva. The
* current definitions here (2023-01-01) are sufficient to override Minerva
* without use of the hlist-separated class. The most problematic styles were
* related to margin, padding, and the bullet. Check files listed at
* [[MediaWiki talk:Common.css/to do#hlist-separated]]
*/
/*
* TODO: When the majority of readership supports it (or some beautiful world
* in which grade C support is above the minimum threshold), use :is()
*/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so:
*.hlist dt:not(:last-child)::after {
* content: ": ";
*}
*.hlist dd:not(:last-child)::after,
*.hlist li:not(:last-child)::after {
* content: " · ";
* font-weight: bold;
*}
*/
/* Generate interpuncts */
.hlist dt::after {
content: ": ";
}
.hlist dd::after,
.hlist li::after {
content: " · ";
font-weight: bold;
}
.hlist dd:last-child::after,
.hlist dt:last-child::after,
.hlist li:last-child::after {
content: none;
}
/* Add parentheses around nested lists */
.hlist dd dd:first-child::before,
.hlist dd dt:first-child::before,
.hlist dd li:first-child::before,
.hlist dt dd:first-child::before,
.hlist dt dt:first-child::before,
.hlist dt li:first-child::before,
.hlist li dd:first-child::before,
.hlist li dt:first-child::before,
.hlist li li:first-child::before {
content: " (";
font-weight: normal;
}
.hlist dd dd:last-child::after,
.hlist dd dt:last-child::after,
.hlist dd li:last-child::after,
.hlist dt dd:last-child::after,
.hlist dt dt:last-child::after,
.hlist dt li:last-child::after,
.hlist li dd:last-child::after,
.hlist li dt:last-child::after,
.hlist li li:last-child::after {
content: ")";
font-weight: normal;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) "\a0";
}
.hlist dd ol > li:first-child::before,
.hlist dt ol > li:first-child::before,
.hlist li ol > li:first-child::before {
content: " (" counter(listitem) "\a0";
}
8c9dd9c9c00f30eead17fe10f51d183333e81f33
Module:List
828
828
1286
1285
2025-08-23T01:31:51Z
Sharparam
284703
1 revision imported
Scribunto
text/plain
local libUtil = require('libraryUtil')
local checkType = libUtil.checkType
local mTableTools = require('Module:TableTools')
local p = {}
local listTypes = {
['bulleted'] = true,
['unbulleted'] = true,
['horizontal'] = true,
['ordered'] = true,
['horizontal_ordered'] = true
}
function p.makeListData(listType, args)
-- Constructs a data table to be passed to p.renderList.
local data = {}
-- Classes and TemplateStyles
data.classes = {}
data.templatestyles = ''
if listType == 'horizontal' or listType == 'horizontal_ordered' then
table.insert(data.classes, 'hlist')
data.templatestyles = mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Hlist/styles.css' }
}
elseif listType == 'unbulleted' then
table.insert(data.classes, 'plainlist')
data.templatestyles = mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Plainlist/styles.css' }
}
end
table.insert(data.classes, args.class)
-- Main div style
data.style = args.style
-- Indent for horizontal lists
if listType == 'horizontal' or listType == 'horizontal_ordered' then
local indent = tonumber(args.indent)
indent = indent and indent * 1.6 or 0
if indent > 0 then
data.marginLeft = indent .. 'em'
end
end
-- List style types for ordered lists
-- This could be "1, 2, 3", "a, b, c", or a number of others. The list style
-- type is either set by the "type" attribute or the "list-style-type" CSS
-- property.
if listType == 'ordered' or listType == 'horizontal_ordered' then
data.listStyleType = args.list_style_type or args['list-style-type']
data.type = args['type']
-- Detect invalid type attributes and attempt to convert them to
-- list-style-type CSS properties.
if data.type
and not data.listStyleType
and not tostring(data.type):find('^%s*[1AaIi]%s*$')
then
data.listStyleType = data.type
data.type = nil
end
end
-- List tag type
if listType == 'ordered' or listType == 'horizontal_ordered' then
data.listTag = 'ol'
else
data.listTag = 'ul'
end
-- Start number for ordered lists
data.start = args.start
if listType == 'horizontal_ordered' then
-- Apply fix to get start numbers working with horizontal ordered lists.
local startNum = tonumber(data.start)
if startNum then
data.counterReset = 'listitem ' .. tostring(startNum - 1)
end
end
-- List style
-- ul_style and ol_style are included for backwards compatibility. No
-- distinction is made for ordered or unordered lists.
data.listStyle = args.list_style
-- List items
-- li_style is included for backwards compatibility. item_style was included
-- to be easier to understand for non-coders.
data.itemStyle = args.item_style or args.li_style
data.items = {}
for _, num in ipairs(mTableTools.numKeys(args)) do
local item = {}
item.content = args[num]
item.style = args['item' .. tostring(num) .. '_style']
or args['item_style' .. tostring(num)]
item.value = args['item' .. tostring(num) .. '_value']
or args['item_value' .. tostring(num)]
table.insert(data.items, item)
end
return data
end
function p.renderList(data)
-- Renders the list HTML.
-- Return the blank string if there are no list items.
if type(data.items) ~= 'table' or #data.items < 1 then
return ''
end
-- Render the main div tag.
local root = mw.html.create('div')
for _, class in ipairs(data.classes or {}) do
root:addClass(class)
end
root:css{['margin-left'] = data.marginLeft}
if data.style then
root:cssText(data.style)
end
-- Render the list tag.
local list = root:tag(data.listTag or 'ul')
list
:attr{start = data.start, type = data.type}
:css{
['counter-reset'] = data.counterReset,
['list-style-type'] = data.listStyleType
}
if data.listStyle then
list:cssText(data.listStyle)
end
-- Render the list items
for _, t in ipairs(data.items or {}) do
local item = list:tag('li')
if data.itemStyle then
item:cssText(data.itemStyle)
end
if t.style then
item:cssText(t.style)
end
item
:attr{value = t.value}
:wikitext(t.content)
end
return data.templatestyles .. tostring(root)
end
function p.renderTrackingCategories(args)
local isDeprecated = false -- Tracks deprecated parameters.
for k, v in pairs(args) do
k = tostring(k)
if k:find('^item_style%d+$') or k:find('^item_value%d+$') then
isDeprecated = true
break
end
end
local ret = ''
if isDeprecated then
ret = ret .. '[[Category:List templates with deprecated parameters]]'
end
return ret
end
function p.makeList(listType, args)
if not listType or not listTypes[listType] then
error(string.format(
"bad argument #1 to 'makeList' ('%s' is not a valid list type)",
tostring(listType)
), 2)
end
checkType('makeList', 2, args, 'table')
local data = p.makeListData(listType, args)
local list = p.renderList(data)
local trackingCategories = p.renderTrackingCategories(args)
return list .. trackingCategories
end
for listType in pairs(listTypes) do
p[listType] = function (frame)
local mArguments = require('Module:Arguments')
local origArgs = mArguments.getArgs(frame, {
frameOnly = ((frame and frame.args and frame.args.frameonly or '') ~= ''),
valueFunc = function (key, value)
if not value or not mw.ustring.find(value, '%S') then return nil end
if mw.ustring.find(value, '^%s*[%*#;:]') then
return value
else
return value:match('^%s*(.-)%s*$')
end
return nil
end
})
-- Copy all the arguments to a new table, for faster indexing.
local args = {}
for k, v in pairs(origArgs) do
args[k] = v
end
return p.makeList(listType, args)
end
end
return p
44af96bdee7ebfa2ecf19acd4461d7a35c75856a
Template:Navbox/Rings
10
292
1287
1175
2025-08-23T01:44:43Z
Sharparam
284703
Add more rings
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Arcane|Arcane]]
* [[Ring of Blessed Hand|Blessed Hand]]
* [[Ring of Burning Desire|Burning Desire]]
* [[Ring of Casting Speed|Casting Speed]]
* [[Ring of Colossus|Colossus]]
* [[Ring of Command|Command]]
* [[Ring of Decay|Decay]]
* [[Ring of Degravitas|Degravitas]]
* [[Ring of Entropy|Entropy]]
* [[Ring of Giant|Giant]]
* [[Ring of Gluttony|Gluttony]]
* [[Ring of Gravitas|Gravitas]]
* [[Ring of Hawk|Hawk]]
* [[Ring of Minor Lifesteal|Minor Lifesteal]]
* [[Ring of Potential|Potential]]
** [[Ring of Minor Potential|Minor]]
* [[Ring of Penetration|Penetration]]
* [[Ring of Power|Power]]
* [[Ring of Rammstein|Rammstein]]
* [[The Scholar's Ring|Scholar]]
* [[Ring of Serpent|Serpent]]
* [[Ring of Silence|Silence]]
* [[Ring of Slumber|Slumber]]
* [[Ring of Speed|Speed]]
* [[Ring of Stamina|Stamina]]
** [[Ring of Lesser Stamina|Lesser]]
* [[Ring of Talent|Talent]]
** [[Ring of Lesser Talent|Lesser]]
** [[Ring of Exceeding Talent|Exceeding]]
* [[Ring of Travel|Travel]]
* Vitality
** [[Ring of Minor Vitality|Minor]]
** [[Ring of Greater Vitality|Greater]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
2260a141cd1e5e4eeef17c8a4924046ea2dadb61
Template:Navbox/Amulets
10
441
1288
648
2025-08-23T01:47:03Z
Sharparam
284703
Add more amulets
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Amulets
| title = [[Amulets]]
| list1 =
* [[Amulet of Arcane]]
* [[Amulet of Arcane Protection]]
* [[Amulet of Divine Might]]
* [[Amulet of Evasion]]
* [[Amulet of Flux Leech]]
* [[Amulet of Recovery]]
* [[Amulet of Stability]]
* [[Amulet of Vitality]]
** [[Amulet of Minor Vitality|Minor]]
* [[Tactician's Amulet]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
efc0dd0f4023e758ff3aef9dd09becfd9d54cbcd
Template:Navbox/Locations
10
293
1289
383
2025-08-23T01:48:24Z
Sharparam
284703
Use proper sublists
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]]
** [[Monastery#Lower|Lower]]
** [[Monastery#Upper|Upper]]
* [[Blok 6147]]
* [[Rain District]]
** [[Rain District#Sewers|Sewers]]
** [[Rain District#Center|Center]]
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]]
** [[Uranopolis#Tower Complex|Tower Complex]]
** [[Uranopolis#Lone Tower|Lone Tower]]
* [[Ghost Town]]
** [[Ghost Town#Floor 13|Floor 13]]
** [[Ghost Town#Floor 1|Floor 1]]
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly]]
* [[Unknown (location)|Unknown]]
* [[Vermillion Fields]]
** [[Vermillion Fields#Plaza|Plaza]]
** [[Vermillion Fields#Temple|Temple]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
3d0740e2cdedd61bc5d5a8b9e839a3fc4e3c69ee
Template:Navbox/Armor
10
439
1290
646
2025-08-23T01:54:03Z
Sharparam
284703
Add more helmets
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| group3 = [[Chestguards]]
| list3 =
* [[Citadel Warrior Chest]]
* [[Corrupted Cuirass]]
* [[Librarian Overcoat]]
* [[Sentinel Chest]]
| group4 = [[Legguards]]
| list4 =
* [[Librarian Trousers]]
* [[Sentinel Legguard]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
bcd48e9c7633d725db1a89ef1b7dfb45647860d7
1291
1290
2025-08-23T01:56:48Z
Sharparam
284703
Add more pauldrons
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Citadel Warrior Chest]]
* [[Corrupted Cuirass]]
* [[Librarian Overcoat]]
* [[Sentinel Chest]]
| group4 = [[Legguards]]
| list4 =
* [[Librarian Trousers]]
* [[Sentinel Legguard]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
c436c20073411ed82436959f407d120e73a84cb6
1292
1291
2025-08-23T02:00:38Z
Sharparam
284703
Add more chestguards
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Librarian Trousers]]
* [[Sentinel Legguard]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
7a8603530e7b9ce9a79bf61c3ce2fb047c5ee4d4
1293
1292
2025-08-23T02:03:56Z
Sharparam
284703
Add more legguards
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Bone Legs]]
* [[Citadel Defender Legguards]]
* [[Citadel Warrior Legguards]]
* [[Contractor Legs]]
* [[Crow Legguard]]
* [[Desert Corp Legs]]
* [[Hunter Legguards]]
* [[Librarian Trousers]]
* [[Ranger Pants]]
* [[Reinforced Bone Legguard]]
* [[Restless Legguard]]
* [[Ronin Pants]]
* [[Sentinel Legguard]]
* [[Spectre Pants]]
* [[Stalker's Pants]]
* [[Technomancer Legs]]
* [[Templar Legs]]
* [[Titan Slayer Legs]]
* [[Utility Uniform Pants]]
* [[Zealot Legs]]
| group5 = [[Gauntlets]]
| list5 =
* [[Sentinel Gauntlets]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
2b369a603af9b6fb14a83d6348476e1f03f2f0bc
1294
1293
2025-08-23T02:07:51Z
Sharparam
284703
Add more gauntlets (Spectre Gauntlets and Ronin Gauntlets are typod in-game as "Spectre Gauntlent" and "Ronin Gauntlent")
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Bone Legs]]
* [[Citadel Defender Legguards]]
* [[Citadel Warrior Legguards]]
* [[Contractor Legs]]
* [[Crow Legguard]]
* [[Desert Corp Legs]]
* [[Hunter Legguards]]
* [[Librarian Trousers]]
* [[Ranger Pants]]
* [[Reinforced Bone Legguard]]
* [[Restless Legguard]]
* [[Ronin Pants]]
* [[Sentinel Legguard]]
* [[Spectre Pants]]
* [[Stalker's Pants]]
* [[Technomancer Legs]]
* [[Templar Legs]]
* [[Titan Slayer Legs]]
* [[Utility Uniform Pants]]
* [[Zealot Legs]]
| group5 = [[Gauntlets]]
| list5 =
* [[Bone Gloves]]
* [[Citadel Defender Gauntlets]]
* [[Citadel Warrior Gauntlets]]
* [[Contractor Gloves]]
* [[Desert Corp Gloves]]
* [[Hunter Gloves]]
* [[Ranger Gloves]]
* [[Reinforced Bone Gauntlets]]
* [[Restless Gauntlets]]
* [[Ronin Gauntlets]]
* [[Sentinel Gauntlets]]
* [[Spectre Gauntlets]]
* [[Stalker's Gloves]]
* [[Technomancer Gloves]]
* [[Templar Gloves]]
* [[Titan Slayer Gloves]]
* [[Utility Uniform Gloves]]
* [[Zealot Gloves]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Citadel Warrior]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Sentinel]]
* [[Techpriest]]
* [[Vengeance]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
8f606cebd5eeb2a0564bad423eafcfc863c00d70
1295
1294
2025-08-23T02:11:09Z
Sharparam
284703
Add more armor sets
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Bone Legs]]
* [[Citadel Defender Legguards]]
* [[Citadel Warrior Legguards]]
* [[Contractor Legs]]
* [[Crow Legguard]]
* [[Desert Corp Legs]]
* [[Hunter Legguards]]
* [[Librarian Trousers]]
* [[Ranger Pants]]
* [[Reinforced Bone Legguard]]
* [[Restless Legguard]]
* [[Ronin Pants]]
* [[Sentinel Legguard]]
* [[Spectre Pants]]
* [[Stalker's Pants]]
* [[Technomancer Legs]]
* [[Templar Legs]]
* [[Titan Slayer Legs]]
* [[Utility Uniform Pants]]
* [[Zealot Legs]]
| group5 = [[Gauntlets]]
| list5 =
* [[Bone Gloves]]
* [[Citadel Defender Gauntlets]]
* [[Citadel Warrior Gauntlets]]
* [[Contractor Gloves]]
* [[Desert Corp Gloves]]
* [[Hunter Gloves]]
* [[Ranger Gloves]]
* [[Reinforced Bone Gauntlets]]
* [[Restless Gauntlets]]
* [[Ronin Gauntlets]]
* [[Sentinel Gauntlets]]
* [[Spectre Gauntlets]]
* [[Stalker's Gloves]]
* [[Technomancer Gloves]]
* [[Templar Gloves]]
* [[Titan Slayer Gloves]]
* [[Utility Uniform Gloves]]
* [[Zealot Gloves]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Bone]]
* [[Citadel Defender]]
* [[Citadel Warrior]]
* [[Contractor]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Ranger]]
* [[Reinforced Bone]]
* [[Restless]]
* [[Ronin (armor set)|Ronin]]
* [[Sentinel]]
* [[Spectre (armor set)|Spectre]]
* [[Technomancer (armor set)|Technomancer]]
* [[Techpriest]]
* [[Templar (armor set)|Templar]]
* [[Titan Slayer (armor set)||Titan Slayer]]
* [[Utility Uniform]]
* [[Vengeance]]
* [[Zealot (armor set)|Zealot]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
da89db5cbaeed06ced302a71316862655899bbbb
1296
1295
2025-08-23T02:12:27Z
Sharparam
284703
Add more armor sets
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Bone Legs]]
* [[Citadel Defender Legguards]]
* [[Citadel Warrior Legguards]]
* [[Contractor Legs]]
* [[Crow Legguard]]
* [[Desert Corp Legs]]
* [[Hunter Legguards]]
* [[Librarian Trousers]]
* [[Ranger Pants]]
* [[Reinforced Bone Legguard]]
* [[Restless Legguard]]
* [[Ronin Pants]]
* [[Sentinel Legguard]]
* [[Spectre Pants]]
* [[Stalker's Pants]]
* [[Technomancer Legs]]
* [[Templar Legs]]
* [[Titan Slayer Legs]]
* [[Utility Uniform Pants]]
* [[Zealot Legs]]
| group5 = [[Gauntlets]]
| list5 =
* [[Bone Gloves]]
* [[Citadel Defender Gauntlets]]
* [[Citadel Warrior Gauntlets]]
* [[Contractor Gloves]]
* [[Desert Corp Gloves]]
* [[Hunter Gloves]]
* [[Ranger Gloves]]
* [[Reinforced Bone Gauntlets]]
* [[Restless Gauntlets]]
* [[Ronin Gauntlets]]
* [[Sentinel Gauntlets]]
* [[Spectre Gauntlets]]
* [[Stalker's Gloves]]
* [[Technomancer Gloves]]
* [[Templar Gloves]]
* [[Titan Slayer Gloves]]
* [[Utility Uniform Gloves]]
* [[Zealot Gloves]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Bone]]
* [[Citadel Defender]]
* [[Citadel Warrior]]
* [[Contractor]]
* [[Corrupted (armor set)|Corrupted]]
* [[Crow]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Ranger]]
* [[Reinforced Bone]]
* [[Restless]]
* [[Ronin (armor set)|Ronin]]
* [[Sentinel]]
* [[Spectre (armor set)|Spectre]]
* [[Stalker]]
* [[Technomancer (armor set)|Technomancer]]
* [[Techpriest]]
* [[Templar (armor set)|Templar]]
* [[Titan Slayer (armor set)||Titan Slayer]]
* [[Utility Uniform]]
* [[Vengeance]]
* [[Zealot (armor set)|Zealot]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
90a515a818cacbaa40d4aceba71440c722489d1d
1297
1296
2025-08-23T02:12:44Z
Sharparam
284703
Fix extra pipe
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Bone Legs]]
* [[Citadel Defender Legguards]]
* [[Citadel Warrior Legguards]]
* [[Contractor Legs]]
* [[Crow Legguard]]
* [[Desert Corp Legs]]
* [[Hunter Legguards]]
* [[Librarian Trousers]]
* [[Ranger Pants]]
* [[Reinforced Bone Legguard]]
* [[Restless Legguard]]
* [[Ronin Pants]]
* [[Sentinel Legguard]]
* [[Spectre Pants]]
* [[Stalker's Pants]]
* [[Technomancer Legs]]
* [[Templar Legs]]
* [[Titan Slayer Legs]]
* [[Utility Uniform Pants]]
* [[Zealot Legs]]
| group5 = [[Gauntlets]]
| list5 =
* [[Bone Gloves]]
* [[Citadel Defender Gauntlets]]
* [[Citadel Warrior Gauntlets]]
* [[Contractor Gloves]]
* [[Desert Corp Gloves]]
* [[Hunter Gloves]]
* [[Ranger Gloves]]
* [[Reinforced Bone Gauntlets]]
* [[Restless Gauntlets]]
* [[Ronin Gauntlets]]
* [[Sentinel Gauntlets]]
* [[Spectre Gauntlets]]
* [[Stalker's Gloves]]
* [[Technomancer Gloves]]
* [[Templar Gloves]]
* [[Titan Slayer Gloves]]
* [[Utility Uniform Gloves]]
* [[Zealot Gloves]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Bone]]
* [[Citadel Defender]]
* [[Citadel Warrior]]
* [[Contractor]]
* [[Corrupted (armor set)|Corrupted]]
* [[Crow]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Ranger]]
* [[Reinforced Bone]]
* [[Restless]]
* [[Ronin (armor set)|Ronin]]
* [[Sentinel]]
* [[Spectre (armor set)|Spectre]]
* [[Stalker]]
* [[Technomancer (armor set)|Technomancer]]
* [[Techpriest]]
* [[Templar (armor set)|Templar]]
* [[Titan Slayer (armor set)|Titan Slayer]]
* [[Utility Uniform]]
* [[Vengeance]]
* [[Zealot (armor set)|Zealot]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
a1d9f80f3b1043def39295dc0d2dca65b7f9ed7b
Template:Infobox/Armor
10
453
1298
1190
2025-08-23T02:19:06Z
Sharparam
284703
Add more armor set special cases
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=armor
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Weight,Set,Passives
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| helm
| helmet = [[Helmet]]
| pauldron
| pauldrons = [[Pauldrons]]
| chestguard = [[Chestguard]]
| legguard
| legguards = [[Legguard]]
| gauntlet
| gauntlets = [[Gauntlet]]
| #default = {{{Type}}}
}}}}
|Set={{#if:{{{Set|}}}|{{#switch:{{lc:{{{Set}}}}}
| corrupted = [[Corrupted (armor set)|Corrupted]]
| librarian = [[Librarian (armor set)|Librarian]]
| ronin = [[Ronin (armor set)|Ronin]]
| spectre = [[Spectre (armor set)|Spectre]]
| technomancer = [[Technomancer (armor set)|Technomancer]]
| templar = [[Templar (armor set)|Templar]]
| titan slayer = [[Titan Slayer (armor set)|Titan Slayer]]
| zealot = [[Zealot (armor set)|Zealot]]
| #default = [[{{{Set}}}]]
}}}}
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \!
| token = @@@@
| pattern = [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|tabs=
Mk0,
Mk1,
Mk2,
Mk3,
Mk4,
Mk5
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| helmet = [[Category:Helmets]]
| pauldrons = [[Category:Pauldrons]]
| chestguard = [[Category:Chestguards]]
| legguard = [[Category:Legguards]]
| gauntlet = [[Category:Gauntlets]]
| #default = [[Category:Armor]]
}}{{Armor/CargoStore
|name={{{title|}}}
|setname={{{Set|}}}
|type={{{Type|}}}
|weight={{{Weight|}}}
|sharpMk0={{{Mk0_Sharp|}}}
|bluntMk0={{{Mk0_Blunt|}}}
|technomancyMk0={{{Mk0_Technomancy|}}}
|sharpMk1={{{Mk1_Sharp|}}}
|bluntMk1={{{Mk1_Blunt|}}}
|technomancyMk1={{{Mk1_Technomancy|}}}
|sharpMk2={{{Mk2_Sharp|}}}
|bluntMk2={{{Mk2_Blunt|}}}
|technomancyMk2={{{Mk2_Technomancy|}}}
|sharpMk3={{{Mk3_Sharp|}}}
|bluntMk3={{{Mk3_Blunt|}}}
|technomancyMk3={{{Mk3_Technomancy|}}}
|sharpMk4={{{Mk4_Sharp|}}}
|bluntMk4={{{Mk4_Blunt|}}}
|technomancyMk4={{{Mk4_Technomancy|}}}
|sharpMk5={{{Mk5_Sharp|}}}
|bluntMk5={{{Mk5_Blunt|}}}
|technomancyMk5={{{Mk5_Technomancy|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
4c54a45d5856aaf6e4c9585671b66a336362a99b
Ronin Gauntlets
0
829
1299
2025-08-23T02:21:04Z
Sharparam
284703
Created page with "{{Infobox/Armor | image = Ronin Gauntlets.png | Type = Gauntlets | Weight = Light | Set = Ronin | Mk4_Sharp = 320 | Mk4_Blunt = 320 | Mk4_Technomancy = 199 }} '''Ronin Gauntlets''' are [[gauntlets]] [[armor]] found in {{BFF}}. == Bugs == * In-game, the item has a typo and is called "Ronin Gauntlent". {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| image = Ronin Gauntlets.png
| Type = Gauntlets
| Weight = Light
| Set = Ronin
| Mk4_Sharp = 320
| Mk4_Blunt = 320
| Mk4_Technomancy = 199
}}
'''Ronin Gauntlets''' are [[gauntlets]] [[armor]] found in {{BFF}}.
== Bugs ==
* In-game, the item has a typo and is called "Ronin Gauntlent".
{{Navbox/Armor}}
506b17c7646045e0f174601826e93201781b7489
Ronin Gauntlent
0
830
1300
2025-08-23T02:21:26Z
Sharparam
284703
Redirected page to [[Ronin Gauntlets]]
wikitext
text/x-wiki
#REDIRECT [[Ronin Gauntlets]]
5c27736bd21d2b919da298f74934ced3e325c077
Spectre Gauntlets
0
831
1301
2025-08-23T02:23:15Z
Sharparam
284703
Created page with "{{Infobox/Armor | image = Spectre Gauntlets.png | Type = Gauntlets | Weight = Light | Set = Spectre | Mk2_Sharp = 166 | Mk2_Blunt = 166 | Mk2_Technomancy = 364 }} '''{{PAGENAME}}''' are [[gauntlets]] [[armor]] found in {{BFF}}. == Bugs == * In-game, the item has a typo and is called "Spectre Gauntlent". {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Infobox/Armor
| image = Spectre Gauntlets.png
| Type = Gauntlets
| Weight = Light
| Set = Spectre
| Mk2_Sharp = 166
| Mk2_Blunt = 166
| Mk2_Technomancy = 364
}}
'''{{PAGENAME}}''' are [[gauntlets]] [[armor]] found in {{BFF}}.
== Bugs ==
* In-game, the item has a typo and is called "Spectre Gauntlent".
{{Navbox/Armor}}
cbde60c139aa72b99538a54ff08d455e3e831b93
File:Spectre Gauntlets.png
6
832
1302
2025-08-23T02:24:06Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/icon_spectregauntlet
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/icon_spectregauntlet
}}
== Licensing ==
{{License|game}}
809b44d5f3a0d45f28cf1eac39078f6b5851494f
File:Ronin Gauntlets.png
6
833
1303
2025-08-23T02:24:46Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/icon_roningauntlet
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armor/icon_roningauntlet
}}
== Licensing ==
{{License|game}}
243c54f0195a7379f152837e67f02d3ad8ce6f92
Template:Navbox/Weapons
10
438
1304
1275
2025-08-23T02:28:46Z
Sharparam
284703
Add more weapons
wikitext
text/x-wiki
<!-- Weapons must be listed in alphabetical order! -->
{{Navbox
| {{{1|}}}
| template = Navbox/Weapons
| title = [[Weapons]]
| group1 = [[One-handed weapons|One-handed]]
| list1 =
* [[Arming Sword]]
* [[Industrial Axe]]
* [[Industrial Mace]]
* [[Iron Pipe]]
* [[Longsword]]
* [[Machinist's Hammer]]
* [[Morning Star]]
* [[Paladin Mace]]
* [[Ratagan Sabre]]
* [[Scimitar]]
* [[Soul Breaker]]
* [[Tire Iron]]
* [[Torch]]
* [[Woodchopper]]
| group2 = [[Two-handed weapons|Two-handed]]
| list2 =
* [[Anastasia]]
* [[Claymore]]
* [[Crescent Axe]]
* [[Faussart]]
* [[Halberd]]
* [[Mechanical Tenderizer]]
* [[Nodachi]]
* [[Royal Claymore]]
* [[Rusty Claymore]]
* [[Solaris]]
* [[Soul Reaper]]
* [[Valtiel]]
| group2.1 = [[Dual Wields]]
| list2.1 =
* [[Blades of Atropos]]
* [[Daggers]]
* [[Kamas]]
* [[Katanas]]
* [[Khopeshs]]
* [[Lacerators]]
| group2.2 = [[Twinblades]]
| list2.2 =
* [[Marrow]]
* [[Twinblade]]
| group2.3 = [[Greatweapons]]
| list2.3 =
* [[Armor Buster]]
* [[Divine Greataxe]]
* [[Eviscerator]]
* [[Greathammer]]
* [[Titan Slayer Greatsword]]
| group3 = [[Ranged weapons|Ranged]]
| list3 = {{Navbox/Ranged weapons|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
be21d6c7ce009c6251403dbd8cd31af5e72ff0b7
Template:Navbox/Consumables
10
286
1305
1256
2025-08-23T02:34:04Z
Sharparam
284703
Add more consumables
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Asylum Brew]]
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
* [[Piercing Arrow Pack]]
| group2 = [[Fluids]]
| list2 =
* [[Ionization Fluid]]
** [[Lesser Ionization Fluid|Lesser]]
** [[Greater Ionization Fluid|Greater]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
** [[Greater Regenerative Fluid|Greater]]
* [[Restorative Fluid]]
** [[Lesser Restorative Fluid|Lesser]]
** [[Greater Restorative Fluid|Greater]]
| group3 = [[Concoctions]]
| list3 =
* [[Diver's Lungs Concoction]]
** * [[Improved Diver's Lungs Concoction|Improved]]
* [[Dreadguard's Concoction]]
** [[Greater Dreadguard's Concoction|Greater]]
* [[Experience Concoction]]
* [[Fluxshield Concoction]]
* [[Forsaken Concoction]]
** [[Greater Forsaken Concoction|Greater]]
* [[Indestructible Concoction]]
* [[Jaeger's Concoction]]
** [[Greater Jaeger's Concoction|Greater]]
* [[Mystery Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Technomancer's Concoction]]
** [[Greater Technomancer's Concoction|Greater]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Agility]]
* [[Concoction: All Attributes]]
* [[Concoction: Berserker's Tenacity]]
* [[Concoction: Constitution]]
* [[Concoction: Flux Regen]]
* [[Concoction: Health Regen]]
* [[Concoction: Intelligence]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Powerful Immune System]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Zealot's Tears]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
9dade871e30ecba44927d6ec0d33ecebdc66ff4b
1306
1305
2025-08-23T02:34:18Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Asylum Brew]]
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
* [[Piercing Arrow Pack]]
| group2 = [[Fluids]]
| list2 =
* [[Ionization Fluid]]
** [[Lesser Ionization Fluid|Lesser]]
** [[Greater Ionization Fluid|Greater]]
* [[Mystery Concoction]]
* [[Regenerative Fluid]]
** [[Greater Regenerative Fluid|Greater]]
* [[Restorative Fluid]]
** [[Lesser Restorative Fluid|Lesser]]
** [[Greater Restorative Fluid|Greater]]
| group3 = [[Concoctions]]
| list3 =
* [[Diver's Lungs Concoction]]
** [[Improved Diver's Lungs Concoction|Improved]]
* [[Dreadguard's Concoction]]
** [[Greater Dreadguard's Concoction|Greater]]
* [[Experience Concoction]]
* [[Fluxshield Concoction]]
* [[Forsaken Concoction]]
** [[Greater Forsaken Concoction|Greater]]
* [[Indestructible Concoction]]
* [[Jaeger's Concoction]]
** [[Greater Jaeger's Concoction|Greater]]
* [[Mystery Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Technomancer's Concoction]]
** [[Greater Technomancer's Concoction|Greater]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Agility]]
* [[Concoction: All Attributes]]
* [[Concoction: Berserker's Tenacity]]
* [[Concoction: Constitution]]
* [[Concoction: Flux Regen]]
* [[Concoction: Health Regen]]
* [[Concoction: Intelligence]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Powerful Immune System]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Zealot's Tears]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
6b066a11cab7ab8aef0b4d4e59c636e529dd0b3e
Template:Navbox/Amulets
10
441
1307
1288
2025-08-23T02:36:27Z
Sharparam
284703
Add more amulets
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Amulets
| title = [[Amulets]]
| list1 =
* [[Amulet of Arcane]]
* [[Amulet of Arcane Protection]]
* [[Amulet of Divine Might]]
* [[Amulet of Evasion]]
* [[Amulet of Flux Leech]]
* [[Amulet of Focus]]
* [[Amulet of Recovery]]
* [[Amulet of Stability]]
* [[Amulet of Vitality]]
** [[Amulet of Minor Vitality|Minor]]
* [[Bulwark Amulet]]
* [[Nimble Amulet]]
* [[Piercing Amulet]]
* [[Tactician's Amulet]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
8d160988dbf0290bbb606baaea462fee7463d094
1322
1307
2025-08-23T03:04:44Z
Sharparam
284703
Add [[Amulet of Wandering]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Amulets
| title = [[Amulets]]
| list1 =
* [[Amulet of Arcane]]
* [[Amulet of Arcane Protection]]
* [[Amulet of Divine Might]]
* [[Amulet of Evasion]]
* [[Amulet of Flux Leech]]
* [[Amulet of Focus]]
* [[Amulet of Recovery]]
* [[Amulet of Stability]]
* [[Amulet of Vitality]]
** [[Amulet of Minor Vitality|Minor]]
* [[Amulet of Wandering]]
* [[Bulwark Amulet]]
* [[Nimble Amulet]]
* [[Piercing Amulet]]
* [[Tactician's Amulet]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
ec6c5c481f8f8a31910ca17e40470fc3bd9ed245
File:Tactician's Amulet.png
6
834
1308
2025-08-23T02:38:10Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/BranceletsAndNecklaces/Necklaces_Icons/512/T_Necklace32_512
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/BranceletsAndNecklaces/Necklaces_Icons/512/T_Necklace32_512
}}
== Licensing ==
{{License|game}}
59bfa39ec0da37d87eccd2eab635b17fa49deabc
Tactician's Amulet
0
518
1309
800
2025-08-23T02:43:04Z
Sharparam
284703
Add overview
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Tactician's Amulet.png
| Effects = Removes invincibility frames
| Passives = Vulnerable Dodge
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Overview ==
In its base form, the amulet simply removes invincibility frames while increasing the distance covered when dashing and dodging.
However, at [[The Handler]], it can be used in [[manufacturing]] to craft one of four other amulets:
* [[Amulet of Focus]]
* [[Bulwark Amulet]]
* [[Nimble Amulet]]
* [[Piercing Amulet]]
Since only one [[Tactician's Amulet]] can be obtained per [[New Game Plus|NG cycle]], it is beneficial to craft one of the above amulets before starting the next cycle, as a new Tactician's Amulet can only be picked up if it's not in the player's inventory already (all of the crafted variants inherit the base effects of this amulet).
{{Navbox/Amulets}}
dacac9fdf121e0684ede31bfafe489603f22a78c
Template:Infobox/Amulet
10
564
1310
883
2025-08-23T02:47:09Z
Sharparam
284703
Add sections for effects and passives
wikitext
text/x-wiki
<includeonly>{{#invoke:infobox|main
| kind = amulet
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections = Basic Info
| Basic Info = Effects,Passives
| Effects = {{#listmap:
| list = {{{Effects|}}}
| outsep = \n
| token = @@@@
| pattern = * @@@@
| intro = \{\{Plainlist\!
| outro = \}\}
}}
| Passives = {{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
}}
{{Main other|[[Category:Amulets]]}}</includeonly>
<noinclude>{{Documentation}}</noinclude>
bb53ff620ce14ed2d3683541d7ece2871df0da5f
Template:Infobox/Passive
10
835
1311
2025-08-23T02:50:53Z
Sharparam
284703
Created page with "<includeonly>{{#invoke:Infobox|main | kind = passive | sep = , | title = {{{title|{{PAGENAME}}}}} | image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}} | sections = DescriptionSection | DescriptionSection = Description | DescriptionSection_label = Description | Description_nolabel = yes }}{{Main other|[[Category:Passives]]}}</includeonly><!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind = passive
| sep = ,
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections = DescriptionSection
| DescriptionSection = Description
| DescriptionSection_label = Description
| Description_nolabel = yes
}}{{Main other|[[Category:Passives]]}}</includeonly><!--
--><noinclude>{{Documentation}}</noinclude>
dfaec1c39c1b442f2ae1c8c6796f881932298cf3
Template:Infobox/Passive/doc
10
836
1312
2025-08-23T02:52:30Z
Sharparam
284703
Created page with "== Examples == {{Infobox/Passive | title = Example Passive | image = Example Passive.png | Description = Increases your stats to ungodly amounts. }} <syntaxhighlight lang="wikitext"> {{Infobox/Passive | title = Example Passive | image = Example Passive.png | Description = Increases your stats to ungodly amounts. }} </syntaxhighlight> <includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== Examples ==
{{Infobox/Passive
| title = Example Passive
| image = Example Passive.png
| Description = Increases your stats to ungodly amounts.
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Passive
| title = Example Passive
| image = Example Passive.png
| Description = Increases your stats to ungodly amounts.
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
0d7069df917ddb42da6611a4af4fcda6cd978ea5
Vulnerable Dodge
0
837
1313
2025-08-23T02:54:03Z
Sharparam
284703
Created page with "{{Infobox/Passive | image = Vulnerable Dodge.png | Description = Increases the distance of dodges and dashes but removes invulnerability frames. }} '''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}. {{Navbox/Passives}}"
wikitext
text/x-wiki
{{Infobox/Passive
| image = Vulnerable Dodge.png
| Description = Increases the distance of dodges and dashes but removes invulnerability frames.
}}
'''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
c774d8e6960f89fc80ac704c449f055d907dbf7f
1317
1313
2025-08-23T02:58:33Z
Sharparam
284703
Update image
wikitext
text/x-wiki
{{Infobox/Passive
| image = Universal Passive.png
| Description = Increases the distance of dodges and dashes but removes invulnerability frames.
}}
'''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
11762e3138684cec8a8616597fb1704d9bdc2b56
Template:Navbox/Passives
10
838
1314
2025-08-23T02:55:02Z
Sharparam
284703
Created page with "{{Navbox | {{{1|}}} | state = {{{state|}}} | template = Navbox/Passives | title = [[Passives]] | list = * [[Vulnerable Dodge]] }}<noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Passives
| title = [[Passives]]
| list =
* [[Vulnerable Dodge]]
}}<noinclude>{{Documentation}}</noinclude>
1d9aa0a9800b46db02fc440036ec626d8caa4ab5
Template:Navbox/Passives/doc
10
839
1315
2025-08-23T02:55:42Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Navigation templates]]}}</includeonly><noinclude>[[Category:Template documentation]]</noinclude>
87827f6829955b934e0e8073491c0fef23954bf8
File:Universal Passive.png
6
840
1316
2025-08-23T02:58:09Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Passive_Universal2
}}
This icon is used for several passive abilities in the game.
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Passive_Universal2
}}
This icon is used for several passive abilities in the game.
== Licensing ==
{{License|game}}
6bab71931e37905933cfd1119c55b620985cb04a
Amulet of Arcane Protection
0
516
1318
796
2025-08-23T03:01:16Z
Sharparam
284703
Fix infobox parameters
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Amulet of Arcane Protection.png
| Effects = +1500 [[Technomancy]] armor rating.
| Passives = Techno-Defiance
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Location ==
{{coords|4158|-2902|1459}}
Found near the top side of a shortcut ladder in [[Uranopolis]].
{{Navbox/Amulets}}
af3eb8594ad71b370b85017c7913cee955ba3591
File:Amulet of Arcane Protection.png
6
841
1319
2025-08-23T03:02:25Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/BranceletsAndNecklaces/Necklaces_Icons/512/T_Necklace68_512
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/BranceletsAndNecklaces/Necklaces_Icons/512/T_Necklace68_512
}}
== Licensing ==
{{License|game}}
4f036d0b23a09dd85f8c3f14dd62335dd75fc5a0
Amulet of Evasion
0
517
1320
798
2025-08-23T03:02:49Z
Sharparam
284703
Fix infobox parameters
wikitext
text/x-wiki
{{Infobox/Amulet
| title = {{PAGENAME}}
| image = Amulet of Evasion.png
| Passives = Extended Evasion
}}
'''{{PAGENAME}}''' is an [[Amulets|amulet]] in {{BFF}}.
== Location ==
{{coords|1251|-8419|551}}
Found in [[Ghost Town#Floor 1|Ghost Town (Floor 1)]]. From the [[Homunculus]], go through the doorway and take the left path. When at the outdoors area, take the big stairs up and head immediately right, then to the wall and the item will be in a corner on the right, behind a building.
{{Navbox/Amulets}}
4d3fe784a7954d14811807b628f35ce7b9a209b7
File:Amulet of Evasion.png
6
842
1321
2025-08-23T03:03:29Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/BranceletsAndNecklaces/Necklaces_Icons/512/T_Necklace30_512
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/BranceletsAndNecklaces/Necklaces_Icons/512/T_Necklace30_512
}}
== Licensing ==
{{License|game}}
0d1e6efa1700da514e282787ea2ace8e7908f4bc
Template:Navbox/Rings
10
292
1323
1287
2025-08-23T03:05:49Z
Sharparam
284703
Add [[Ring of Lifesteal]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Rings
| title = [[Rings]]
| list1=
* [[Ring of Arcane|Arcane]]
* [[Ring of Blessed Hand|Blessed Hand]]
* [[Ring of Burning Desire|Burning Desire]]
* [[Ring of Casting Speed|Casting Speed]]
* [[Ring of Colossus|Colossus]]
* [[Ring of Command|Command]]
* [[Ring of Decay|Decay]]
* [[Ring of Degravitas|Degravitas]]
* [[Ring of Entropy|Entropy]]
* [[Ring of Giant|Giant]]
* [[Ring of Gluttony|Gluttony]]
* [[Ring of Gravitas|Gravitas]]
* [[Ring of Hawk|Hawk]]
* [[Ring of Lifesteal|Lifesteal]]
** [[Ring of Minor Lifesteal|Minor]]
* [[Ring of Potential|Potential]]
** [[Ring of Minor Potential|Minor]]
* [[Ring of Penetration|Penetration]]
* [[Ring of Power|Power]]
* [[Ring of Rammstein|Rammstein]]
* [[The Scholar's Ring|Scholar]]
* [[Ring of Serpent|Serpent]]
* [[Ring of Silence|Silence]]
* [[Ring of Slumber|Slumber]]
* [[Ring of Speed|Speed]]
* [[Ring of Stamina|Stamina]]
** [[Ring of Lesser Stamina|Lesser]]
* [[Ring of Talent|Talent]]
** [[Ring of Lesser Talent|Lesser]]
** [[Ring of Exceeding Talent|Exceeding]]
* [[Ring of Travel|Travel]]
* Vitality
** [[Ring of Minor Vitality|Minor]]
** [[Ring of Greater Vitality|Greater]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
bdc1ecefbf4e035927c18284c74a4cacd77078b4
Template:Navbox/Armor
10
439
1324
1297
2025-08-23T03:07:35Z
Sharparam
284703
Add [[Vengeance]] armor pieces
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Armor
| title = [[Armor]]
| group1 = [[Helmets]]
| list1 =
* [[Bone Helmet]]
* [[Citadel Defender Helmet]]
* [[Citadel Warrior Helmet]]
* [[Contractor Helmet]]
* [[Crude Helmet]]
* [[Desert Corp Helmet]]
* [[Deserts Respirator Helmet]]
* [[Elipse Helmet]]
* [[Eris]]
* [[Hunter Mask]]
* [[Hunter Prowler Mask]]
* [[Hunter Veteran Mask]]
* [[Iron Helmet]]
* [[Librarian Hood]]
* [[Mechacenturion]]
* [[Plagued Revenant Helmet]]
* [[Ranger Helmet]]
* [[Reinforced Bone Helmet]]
* [[Restless Helmet]]
* [[Ronin Helmet]]
* [[Sentinel Helmet]]
* [[Skullface Helmet]]
* [[Spectre Helmet]]
* [[Stalker's Hood]]
* [[Technomancer Helmet]]
* [[Techpriest Helmet]]
* [[Templar Helmet]]
* [[Titan Slayer Helmet]]
* [[Vengeance Helmet]]
* [[Visage Respirator Helmet]]
* [[Zealot Helmet]]
| group2 = [[Pauldrons]]
| list2 =
* [[Bone Shoulders]]
* [[Citadel Defender Shoulders]]
* [[Citadel Warrior Shoulders]]
* [[Crow Shoulders]]
* [[Desert Corp Shoulders]]
* [[Hunter Pauldrons]]
* [[Hunter Shoulders]]
* [[Ranger Shoulders]]
* [[Reinforced Bone Shoulders]]
* [[Restless Shoulders]]
* [[Ronin Shoulders]]
* [[Spectre Shoulders]]
* [[Templar Shoulders]]
* [[Titan Slayer Shoulders]]
* [[Zealot Overcoat]]
| group3 = [[Chestguards]]
| list3 =
* [[Bone Cuirass]]
* [[Citadel Defender Chest]]
* [[Citadel Warrior Chest]]
* [[Contractor Chestpiece]]
* [[Corrupted Cuirass]]
* [[Crow Cuirass]]
* [[Desert Corp Cuirass]]
* [[Hunter Coat]]
* [[Hunter Garb]]
* [[Librarian Overcoat]]
* [[Ranger Chestguard]]
* [[Reinforced Bone Cuirass]]
* [[Restless Cuirass]]
* [[Ronin Cuirass]]
* [[Sentinel Chest]]
* [[Spectre Cuirass]]
* [[Stalker's Cuirass]]
* [[Technomancer Chestpiece]]
* [[Templar Chestpiece]]
* [[Titan Slayer Cuirass]]
* [[Utility Uniform Jacket]]
* [[Vengeance Cuirass]]
* [[Zealot Chestpiece]]
| group4 = [[Legguards]]
| list4 =
* [[Bone Legs]]
* [[Citadel Defender Legguards]]
* [[Citadel Warrior Legguards]]
* [[Contractor Legs]]
* [[Crow Legguard]]
* [[Desert Corp Legs]]
* [[Hunter Legguards]]
* [[Librarian Trousers]]
* [[Ranger Pants]]
* [[Reinforced Bone Legguard]]
* [[Restless Legguard]]
* [[Ronin Pants]]
* [[Sentinel Legguard]]
* [[Spectre Pants]]
* [[Stalker's Pants]]
* [[Technomancer Legs]]
* [[Templar Legs]]
* [[Titan Slayer Legs]]
* [[Utility Uniform Pants]]
* [[Vengeance Legs]]
* [[Zealot Legs]]
| group5 = [[Gauntlets]]
| list5 =
* [[Bone Gloves]]
* [[Citadel Defender Gauntlets]]
* [[Citadel Warrior Gauntlets]]
* [[Contractor Gloves]]
* [[Desert Corp Gloves]]
* [[Hunter Gloves]]
* [[Ranger Gloves]]
* [[Reinforced Bone Gauntlets]]
* [[Restless Gauntlets]]
* [[Ronin Gauntlets]]
* [[Sentinel Gauntlets]]
* [[Spectre Gauntlets]]
* [[Stalker's Gloves]]
* [[Technomancer Gloves]]
* [[Templar Gloves]]
* [[Titan Slayer Gloves]]
* [[Utility Uniform Gloves]]
* [[Vengeance Gauntlets]]
* [[Zealot Gloves]]
| group6 = [[Armor sets|Sets]]
| list6 =
* [[Bone]]
* [[Citadel Defender]]
* [[Citadel Warrior]]
* [[Contractor]]
* [[Corrupted (armor set)|Corrupted]]
* [[Crow]]
* [[Desert Corp]]
* [[Librarian (armor set)|Librarian]]
* [[Ranger]]
* [[Reinforced Bone]]
* [[Restless]]
* [[Ronin (armor set)|Ronin]]
* [[Sentinel]]
* [[Spectre (armor set)|Spectre]]
* [[Stalker]]
* [[Technomancer (armor set)|Technomancer]]
* [[Techpriest]]
* [[Templar (armor set)|Templar]]
* [[Titan Slayer (armor set)|Titan Slayer]]
* [[Utility Uniform]]
* [[Vengeance]]
* [[Zealot (armor set)|Zealot]]
| group7 = [[Shields]]
| list7 = {{Navbox/Shields|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
daaa58c3a186b831e3a3961cbe57bf86dbe72b04
Intelligence
0
843
1325
2025-08-23T03:19:49Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects maximum [[flux]] and [[technomancy]] damage. == Overview == Maximum flux increases by 5 between levels 6 and 100, then drops to 2 until level 200. After level 200, maximum flux will increase by 1 for each level. The damage increase varies as the attribute is increased, see the table for details. After intelligence reaches level 200, damage will no longer increase, making the hardcap for bonus damag..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects maximum [[flux]] and [[technomancy]] damage.
== Overview ==
Maximum flux increases by 5 between levels 6 and 100, then drops to 2 until level 200. After level 200, maximum flux will increase by 1 for each level.
The damage increase varies as the attribute is increased, see the table for details. After intelligence reaches level 200, damage will no longer increase, making the hardcap for bonus damage 830%.
{| class="wikitable sortable sticky-header-multi hover-highlight mw-collapsible mw-collapsed" style="text-align: right;"
|-
! class="unsortable" scope="col" rowspan="2" | Intelligence
! class="unsortable" scope="col" rowspan="2" | Max flux
! class="unsortable" scope="col" rowspan="2" | +Tech dmg
! class="unsortable" scope="col" colspan="2" | Increments
|-
! class="unsortable" scope="col" | Max flux
! class="unsortable" scope="col" | +Tech dmg
|-
| 0 || 90 || 80% || 0 || 0%
|-
| 1 || 90 || 80% || 0 || 0%
|-
| 2 || 90 || 80% || 0 || 0%
|-
| 3 || 90 || 80% || 0 || 0%
|-
| 4 || 90 || 80% || 0 || 0%
|-
| 5 || 90 || 80% || 0 || 0%
|-
| 6 || 95 || 83% || 5 || 3%
|-
| 7 || 100 || 86% || 5 || 3%
|-
| 8 || 105 || 89% || 5 || 3%
|-
| 9 || 110 || 92% || 5 || 3%
|-
| 10 || 115 || 95% || 5 || 3%
|-
| 11 || 120 || 99% || 5 || 4%
|-
| 12 || 125 || 103% || 5 || 4%
|-
| 13 || 130 || 107% || 5 || 4%
|-
| 14 || 135 || 111% || 5 || 4%
|-
| 15 || 140 || 115% || 5 || 4%
|-
| 16 || 145 || 120% || 5 || 5%
|-
| 17 || 150 || 125% || 5 || 5%
|-
| 18 || 155 || 130% || 5 || 5%
|-
| 19 || 160 || 135% || 5 || 5%
|-
| 20 || 165 || 140% || 5 || 5%
|-
| 21 || 170 || 150% || 5 || 10%
|-
| 22 || 175 || 160% || 5 || 10%
|-
| 23 || 180 || 170% || 5 || 10%
|-
| 24 || 185 || 180% || 5 || 10%
|-
| 25 || 190 || 190% || 5 || 10%
|-
| 26 || 195 || 200% || 5 || 10%
|-
| 27 || 200 || 210% || 5 || 10%
|-
| 28 || 205 || 220% || 5 || 10%
|-
| 29 || 210 || 230% || 5 || 10%
|-
| 30 || 215 || 240% || 5 || 10%
|-
| 31 || 220 || 252% || 5 || 12%
|-
| 32 || 225 || 264% || 5 || 12%
|-
| 33 || 230 || 276% || 5 || 12%
|-
| 34 || 235 || 288% || 5 || 12%
|-
| 35 || 240 || 300% || 5 || 12%
|-
| 36 || 245 || 312% || 5 || 12%
|-
| 37 || 250 || 324% || 5 || 12%
|-
| 38 || 255 || 336% || 5 || 12%
|-
| 39 || 260 || 348% || 5 || 12%
|-
| 40 || 265 || 360% || 5 || 12%
|-
| 41 || 270 || 372% || 5 || 12%
|-
| 42 || 275 || 384% || 5 || 12%
|-
| 43 || 280 || 396% || 5 || 12%
|-
| 44 || 285 || 408% || 5 || 12%
|-
| 45 || 290 || 420% || 5 || 12%
|-
| 46 || 295 || 432% || 5 || 12%
|-
| 47 || 300 || 444% || 5 || 12%
|-
| 48 || 305 || 456% || 5 || 12%
|-
| 49 || 310 || 468% || 5 || 12%
|-
| 50 || 315 || 480% || 5 || 12%
|-
| 51 || 320 || 483% || 5 || 3%
|-
| 52 || 325 || 486% || 5 || 3%
|-
| 53 || 330 || 489% || 5 || 3%
|-
| 54 || 335 || 492% || 5 || 3%
|-
| 55 || 340 || 495% || 5 || 3%
|-
| 56 || 345 || 498% || 5 || 3%
|-
| 57 || 350 || 501% || 5 || 3%
|-
| 58 || 355 || 504% || 5 || 3%
|-
| 59 || 360 || 507% || 5 || 3%
|-
| 60 || 365 || 510% || 5 || 3%
|-
| 61 || 370 || 513% || 5 || 3%
|-
| 62 || 375 || 516% || 5 || 3%
|-
| 63 || 380 || 519% || 5 || 3%
|-
| 64 || 385 || 522% || 5 || 3%
|-
| 65 || 390 || 525% || 5 || 3%
|-
| 66 || 395 || 528% || 5 || 3%
|-
| 67 || 400 || 531% || 5 || 3%
|-
| 68 || 405 || 534% || 5 || 3%
|-
| 69 || 410 || 537% || 5 || 3%
|-
| 70 || 415 || 540% || 5 || 3%
|-
| 71 || 420 || 543% || 5 || 3%
|-
| 72 || 425 || 546% || 5 || 3%
|-
| 73 || 430 || 549% || 5 || 3%
|-
| 74 || 435 || 552% || 5 || 3%
|-
| 75 || 440 || 555% || 5 || 3%
|-
| 76 || 445 || 558% || 5 || 3%
|-
| 77 || 450 || 561% || 5 || 3%
|-
| 78 || 455 || 564% || 5 || 3%
|-
| 79 || 460 || 567% || 5 || 3%
|-
| 80 || 465 || 570% || 5 || 3%
|-
| 81 || 470 || 573% || 5 || 3%
|-
| 82 || 475 || 576% || 5 || 3%
|-
| 83 || 480 || 579% || 5 || 3%
|-
| 84 || 485 || 582% || 5 || 3%
|-
| 85 || 490 || 585% || 5 || 3%
|-
| 86 || 495 || 588% || 5 || 3%
|-
| 87 || 500 || 591% || 5 || 3%
|-
| 88 || 505 || 594% || 5 || 3%
|-
| 89 || 510 || 597% || 5 || 3%
|-
| 90 || 515 || 600% || 5 || 3%
|-
| 91 || 520 || 603% || 5 || 3%
|-
| 92 || 525 || 606% || 5 || 3%
|-
| 93 || 530 || 609% || 5 || 3%
|-
| 94 || 535 || 612% || 5 || 3%
|-
| 95 || 540 || 615% || 5 || 3%
|-
| 96 || 545 || 618% || 5 || 3%
|-
| 97 || 550 || 621% || 5 || 3%
|-
| 98 || 555 || 624% || 5 || 3%
|-
| 99 || 560 || 627% || 5 || 3%
|-
| 100 || 565 || 630% || 5 || 3%
|-
| 101 || 567 || 632% || 2 || 2%
|-
| 102 || 569 || 634% || 2 || 2%
|-
| 103 || 571 || 636% || 2 || 2%
|-
| 104 || 573 || 638% || 2 || 2%
|-
| 105 || 575 || 640% || 2 || 2%
|-
| 106 || 577 || 642% || 2 || 2%
|-
| 107 || 579 || 644% || 2 || 2%
|-
| 108 || 581 || 646% || 2 || 2%
|-
| 109 || 583 || 648% || 2 || 2%
|-
| 110 || 585 || 650% || 2 || 2%
|-
| 111 || 587 || 652% || 2 || 2%
|-
| 112 || 589 || 654% || 2 || 2%
|-
| 113 || 591 || 656% || 2 || 2%
|-
| 114 || 593 || 658% || 2 || 2%
|-
| 115 || 595 || 660% || 2 || 2%
|-
| 116 || 597 || 662% || 2 || 2%
|-
| 117 || 599 || 664% || 2 || 2%
|-
| 118 || 601 || 666% || 2 || 2%
|-
| 119 || 603 || 668% || 2 || 2%
|-
| 120 || 605 || 670% || 2 || 2%
|-
| 121 || 607 || 672% || 2 || 2%
|-
| 122 || 609 || 674% || 2 || 2%
|-
| 123 || 611 || 676% || 2 || 2%
|-
| 124 || 613 || 678% || 2 || 2%
|-
| 125 || 615 || 680% || 2 || 2%
|-
| 126 || 617 || 682% || 2 || 2%
|-
| 127 || 619 || 684% || 2 || 2%
|-
| 128 || 621 || 686% || 2 || 2%
|-
| 129 || 623 || 688% || 2 || 2%
|-
| 130 || 625 || 690% || 2 || 2%
|-
| 131 || 627 || 692% || 2 || 2%
|-
| 132 || 629 || 694% || 2 || 2%
|-
| 133 || 631 || 696% || 2 || 2%
|-
| 134 || 633 || 698% || 2 || 2%
|-
| 135 || 635 || 700% || 2 || 2%
|-
| 136 || 637 || 702% || 2 || 2%
|-
| 137 || 639 || 704% || 2 || 2%
|-
| 138 || 641 || 706% || 2 || 2%
|-
| 139 || 643 || 708% || 2 || 2%
|-
| 140 || 645 || 710% || 2 || 2%
|-
| 141 || 647 || 712% || 2 || 2%
|-
| 142 || 649 || 714% || 2 || 2%
|-
| 143 || 651 || 716% || 2 || 2%
|-
| 144 || 653 || 718% || 2 || 2%
|-
| 145 || 655 || 720% || 2 || 2%
|-
| 146 || 657 || 722% || 2 || 2%
|-
| 147 || 659 || 724% || 2 || 2%
|-
| 148 || 661 || 726% || 2 || 2%
|-
| 149 || 663 || 728% || 2 || 2%
|-
| 150 || 665 || 730% || 2 || 2%
|-
| 151 || 667 || 732% || 2 || 2%
|-
| 152 || 669 || 734% || 2 || 2%
|-
| 153 || 671 || 736% || 2 || 2%
|-
| 154 || 673 || 738% || 2 || 2%
|-
| 155 || 675 || 740% || 2 || 2%
|-
| 156 || 677 || 742% || 2 || 2%
|-
| 157 || 679 || 744% || 2 || 2%
|-
| 158 || 681 || 746% || 2 || 2%
|-
| 159 || 683 || 748% || 2 || 2%
|-
| 160 || 685 || 750% || 2 || 2%
|-
| 161 || 687 || 752% || 2 || 2%
|-
| 162 || 689 || 754% || 2 || 2%
|-
| 163 || 691 || 756% || 2 || 2%
|-
| 164 || 693 || 758% || 2 || 2%
|-
| 165 || 695 || 760% || 2 || 2%
|-
| 166 || 697 || 762% || 2 || 2%
|-
| 167 || 699 || 764% || 2 || 2%
|-
| 168 || 701 || 766% || 2 || 2%
|-
| 169 || 703 || 768% || 2 || 2%
|-
| 170 || 705 || 770% || 2 || 2%
|-
| 171 || 707 || 772% || 2 || 2%
|-
| 172 || 709 || 774% || 2 || 2%
|-
| 173 || 711 || 776% || 2 || 2%
|-
| 174 || 713 || 778% || 2 || 2%
|-
| 175 || 715 || 780% || 2 || 2%
|-
| 176 || 717 || 782% || 2 || 2%
|-
| 177 || 719 || 784% || 2 || 2%
|-
| 178 || 721 || 786% || 2 || 2%
|-
| 179 || 723 || 788% || 2 || 2%
|-
| 180 || 725 || 790% || 2 || 2%
|-
| 181 || 727 || 792% || 2 || 2%
|-
| 182 || 729 || 794% || 2 || 2%
|-
| 183 || 731 || 796% || 2 || 2%
|-
| 184 || 733 || 798% || 2 || 2%
|-
| 185 || 735 || 800% || 2 || 2%
|-
| 186 || 737 || 802% || 2 || 2%
|-
| 187 || 739 || 804% || 2 || 2%
|-
| 188 || 741 || 806% || 2 || 2%
|-
| 189 || 743 || 808% || 2 || 2%
|-
| 190 || 745 || 810% || 2 || 2%
|-
| 191 || 747 || 812% || 2 || 2%
|-
| 192 || 749 || 814% || 2 || 2%
|-
| 193 || 751 || 816% || 2 || 2%
|-
| 194 || 753 || 818% || 2 || 2%
|-
| 195 || 755 || 820% || 2 || 2%
|-
| 196 || 757 || 822% || 2 || 2%
|-
| 197 || 759 || 824% || 2 || 2%
|-
| 198 || 761 || 826% || 2 || 2%
|-
| 199 || 763 || 828% || 2 || 2%
|-
| 200 || 765 || 830% || 2 || 2%
|}
[[Category:Attributes]]
904a952540b7b412f5d5b7f4b0504f5a22f5ddda
Constitution
0
844
1326
2025-08-23T03:26:18Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects maximum [[health]] and stagger resistance. == Overview == Maximum health starts at 200, with each additional level increasing it by 0, 25, or 50 (see the table for details). After level 65, maximum health increases by 25 for each level. Stagger resistance starts at 5%. Level 6 gives the first increase to stagger resistance by 0.5%, which continues until 45, after which it drops to 0, making the har..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is one of the [[attributes]] in {{BFF}}. It affects maximum [[health]] and stagger resistance.
== Overview ==
Maximum health starts at 200, with each additional level increasing it by 0, 25, or 50 (see the table for details). After level 65, maximum health increases by 25 for each level.
Stagger resistance starts at 5%. Level 6 gives the first increase to stagger resistance by 0.5%, which continues until 45, after which it drops to 0, making the hardcap for bonus stagger resist 25%.
{| class="wikitable sortable sticky-header-multi hover-highlight mw-collapsible mw-collapsed" style="text-align: right;"
|-
! class="unsortable" scope="col" rowspan="2" | Constitution
! class="unsortable" scope="col" rowspan="2" | Max HP
! class="unsortable" scope="col" rowspan="2" | +Stagger res
! class="unsortable" scope="col" colspan="2" | Increments
|-
! class="unsortable" scope="col" | Max HP
! class="unsortable" scope="col" | +Stagger res
|-
| 0 || {{fnum|200}} || 5.0% || 50 || 5.0%
|-
| 1 || {{fnum|200}} || 5.0% || 0 || 0.0%
|-
| 2 || {{fnum|225}} || 5.0% || 25 || 0.0%
|-
| 3 || {{fnum|250}} || 5.0% || 25 || 0.0%
|-
| 4 || {{fnum|275}} || 5.0% || 25 || 0.0%
|-
| 5 || {{fnum|300}} || 5.0% || 25 || 0.0%
|-
| 6 || {{fnum|325}} || 5.5% || 25 || 0.5%
|-
| 7 || {{fnum|350}} || 6.0% || 25 || 0.5%
|-
| 8 || {{fnum|400}} || 6.5% || 50 || 0.5%
|-
| 9 || {{fnum|425}} || 7.0% || 25 || 0.5%
|-
| 10 || {{fnum|475}} || 7.5% || 50 || 0.5%
|-
| 11 || {{fnum|500}} || 8.0% || 25 || 0.5%
|-
| 12 || {{fnum|525}} || 8.5% || 25 || 0.5%
|-
| 13 || {{fnum|575}} || 9.0% || 50 || 0.5%
|-
| 14 || {{fnum|600}} || 9.5% || 25 || 0.5%
|-
| 15 || {{fnum|650}} || 10.0% || 50 || 0.5%
|-
| 16 || {{fnum|700}} || 10.5% || 50 || 0.5%
|-
| 17 || {{fnum|750}} || 11.0% || 50 || 0.5%
|-
| 18 || {{fnum|800}} || 11.5% || 50 || 0.5%
|-
| 19 || {{fnum|850}} || 12.0% || 50 || 0.5%
|-
| 20 || {{fnum|900}} || 12.5% || 50 || 0.5%
|-
| 21 || {{fnum|925}} || 13.0% || 25 || 0.5%
|-
| 22 || {{fnum|950}} || 13.5% || 25 || 0.5%
|-
| 23 || {{fnum|975}} || 14.0% || 25 || 0.5%
|-
| 24 || {{fnum|1000}} || 14.5% || 25 || 0.5%
|-
| 25 || {{fnum|1050}} || 15.0% || 50 || 0.5%
|-
| 26 || {{fnum|1075}} || 15.5% || 25 || 0.5%
|-
| 27 || {{fnum|1100}} || 16.0% || 25 || 0.5%
|-
| 28 || {{fnum|1125}} || 16.5% || 25 || 0.5%
|-
| 29 || {{fnum|1150}} || 17.0% || 25 || 0.5%
|-
| 30 || {{fnum|1200}} || 17.5% || 50 || 0.5%
|-
| 31 || {{fnum|1225}} || 18.0% || 25 || 0.5%
|-
| 32 || {{fnum|1250}} || 18.5% || 25 || 0.5%
|-
| 33 || {{fnum|1275}} || 19.0% || 25 || 0.5%
|-
| 34 || {{fnum|1300}} || 19.5% || 25 || 0.5%
|-
| 35 || {{fnum|1325}} || 20.0% || 25 || 0.5%
|-
| 36 || {{fnum|1350}} || 20.5% || 25 || 0.5%
|-
| 37 || {{fnum|1375}} || 21.0% || 25 || 0.5%
|-
| 38 || {{fnum|1400}} || 21.5% || 25 || 0.5%
|-
| 39 || {{fnum|1425}} || 22.0% || 25 || 0.5%
|-
| 40 || {{fnum|1475}} || 22.5% || 50 || 0.5%
|-
| 41 || {{fnum|1500}} || 23.0% || 25 || 0.5%
|-
| 42 || {{fnum|1525}} || 23.5% || 25 || 0.5%
|-
| 43 || {{fnum|1550}} || 24.0% || 25 || 0.5%
|-
| 44 || {{fnum|1575}} || 24.5% || 25 || 0.5%
|-
| 45 || {{fnum|1600}} || 25.0% || 25 || 0.5%
|-
| 46 || {{fnum|1600}} || 25.0% || 0 || 0.0%
|-
| 47 || {{fnum|1625}} || 25.0% || 25 || 0.0%
|-
| 48 || {{fnum|1650}} || 25.0% || 25 || 0.0%
|-
| 49 || {{fnum|1650}} || 25.0% || 0 || 0.0%
|-
| 50 || {{fnum|1675}} || 25.0% || 25 || 0.0%
|-
| 51 || {{fnum|1700}} || 25.0% || 25 || 0.0%
|-
| 52 || {{fnum|1700}} || 25.0% || 0 || 0.0%
|-
| 53 || {{fnum|1700}} || 25.0% || 0 || 0.0%
|-
| 54 || {{fnum|1700}} || 25.0% || 0 || 0.0%
|-
| 55 || {{fnum|1725}} || 25.0% || 25 || 0.0%
|-
| 56 || {{fnum|1725}} || 25.0% || 0 || 0.0%
|-
| 57 || {{fnum|1725}} || 25.0% || 0 || 0.0%
|-
| 58 || {{fnum|1725}} || 25.0% || 0 || 0.0%
|-
| 59 || {{fnum|1750}} || 25.0% || 25 || 0.0%
|-
| 60 || {{fnum|1750}} || 25.0% || 0 || 0.0%
|-
| 61 || {{fnum|1750}} || 25.0% || 0 || 0.0%
|-
| 62 || {{fnum|1750}} || 25.0% || 0 || 0.0%
|-
| 63 || {{fnum|1750}} || 25.0% || 0 || 0.0%
|-
| 64 || {{fnum|1750}} || 25.0% || 0 || 0.0%
|-
| 65 || {{fnum|1775}} || 25.0% || 25 || 0.0%
|}
[[Category:Attributes]]
c3723f75964d29317b224f3d07316e154a7e63a1
Level
0
707
1327
1096
2025-08-23T03:32:35Z
Sharparam
284703
Add some data for level 30
wikitext
text/x-wiki
{{stub}}
'''{{PAGENAME}}''' is a measure of a player's experience.
== Overview ==
The level increases by gaining experience points through exploration, defeating [[enemies]], and picking up or interacting with [[items]] or [[lore]] objects.
The amount of experience points required to reach further levels will regularly increase, although not with every level.
Every level up also grants two attribute points that can be used to increase player [[attributes]]. When reaching level 25 you get 6 points instead of 2.
The max level is 25, with each [[NG+]] iteration increasing the cap by 5, to a maximum of 40 in [[NG+|NG+3]].
{| class="wikitable sticky-header hover-highlight" style="text-align: right;"
|-
! scope="col" | Level
! scope="col" | EXP to next
! scope="col" | Cost increase
! scope="col" | Total EXP
! scope="col" | Attribute points
! scope="col" | Total attr points
|-
| 0 || {{fnum|480}} || {{fnum|480}} || {{fnum|0}} || 0 || 0
|-
| 1 || {{fnum|1220}} || {{fnum|740}} || {{fnum|480}} || 2 || 2
|-
| 2 || {{fnum|2250}} || {{fnum|1030}} || {{fnum|1700}} || 2 || 4
|-
| 3 || {{fnum|13500}} || {{fnum|11250}} || {{fnum|3950}} || 2 || 6
|-
| 4 || {{fnum|13500}} || {{fnum|0}} || {{fnum|17450}} || 2 || 8
|-
| 5 || {{fnum|15000}} || {{fnum|1500}} || {{fnum|30950}} || 4 || 12
|-
| 6 || {{fnum|15000}} || {{fnum|0}} || {{fnum|45950}} || 2 || 14
|-
| 7 || {{fnum|15000}} || {{fnum|0}} || {{fnum|60950}} || 2 || 16
|-
| 8 || {{fnum|15000}} || {{fnum|0}} || {{fnum|75950}} || 2 || 18
|-
| 9 || {{fnum|15000}} || {{fnum|0}} || {{fnum|90950}} || 2 || 20
|-
| 10 || {{fnum|18500}} || {{fnum|3500}} || {{fnum|105950}} || 4 || 24
|-
| 11 || {{fnum|18500}} || {{fnum|0}} || {{fnum|124450}} || 2 || 26
|-
| 12 || {{fnum|18500}} || {{fnum|0}} || {{fnum|142950}} || 2 || 28
|-
| 13 || {{fnum|18500}} || {{fnum|0}} || {{fnum|161450}} || 2 || 30
|-
| 14 || {{fnum|18500}} || {{fnum|0}} || {{fnum|179950}} || 2 || 32
|-
| 15 || {{fnum|21500}} || {{fnum|3000}} || {{fnum|198450}} || 4 || 36
|-
| 16 || {{fnum|21500}} || {{fnum|0}} || {{fnum|219950}} || 2 || 38
|-
| 17 || {{fnum|21500}} || {{fnum|0}} || {{fnum|241450}} || 2 || 40
|-
| 18 || {{fnum|21500}} || {{fnum|0}} || {{fnum|262950}} || 2 || 42
|-
| 19 || {{fnum|21500}} || {{fnum|0}} || {{fnum|284450}} || 2 || 44
|-
| 20 || {{fnum|25000}} || {{fnum|3500}} || {{fnum|305950}} || 4 || 48
|-
| 21 || {{fnum|25000}} || {{fnum|0}} || {{fnum|330950}} || 2 || 50
|-
| 22 || {{fnum|25000}} || {{fnum|0}} || {{fnum|355950}} || 2 || 52
|-
| 23 || {{fnum|25000}} || {{fnum|0}} || {{fnum|380950}} || 2 || 54
|-
| 24 || {{fnum|25000}} || {{fnum|0}} || {{fnum|405950}} || 2 || 56
|-
| 25 || {{fnum|103420}} || {{fnum|78420}} || {{fnum|430950}} || 6 || 62
|-
| 26 || {{fnum|103430}} || {{fnum|10}} || {{fnum|534370}} || 3 || 65
|-
| 27 || {{fnum|103430}} || {{fnum|0}} || {{fnum|637800}} || 3 || 68
|-
| 28 || {{fnum|103430}} || {{fnum|0}} || {{fnum|741230}} || 3 || 71
|-
| 29 || {{fnum|103430}} || {{fnum|0}} || {{fnum|844660}} || 3 || 74
|-
| 30 || ??? || ??? || {{fnum|948090}} || 6 || 80
|}
[[Category:Game mechanics]]
f6cf6898dcaffb864de12f0ab74a8307f0f83552
Asylum
0
357
1328
477
2025-08-23T04:09:39Z
Sharparam
284703
Add NPC section
wikitext
text/x-wiki
[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls.
}}
== NPCs ==
* [[Inquisitor Commander Alexius]]
{{Navbox/Locations}}
[[Category:Locations]]
f3f760da6e54723bfa17a9677d0604c115bc10b4
1329
1328
2025-08-23T04:10:21Z
Sharparam
284703
Add area boss
wikitext
text/x-wiki
[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls.
}}
== NPCs ==
* [[Inquisitor Commander Alexius]]
== Bosses ==
* [[Plagued Nemesis]]
{{Navbox/Locations}}
[[Category:Locations]]
579690e518d2f45738b4a9969fa23aba0a82777f
MediaWiki:Common.css
8
235
1330
259
2025-08-23T16:43:34Z
Sharparam
284703
Configure accent and content border color for dark theme
css
text/css
/* CSS placed here will be applied to all skins */
/******************************************************************************************
********************************* Start user-edit variables *******************************
******************************************************************************************/
/*****************************************
****** START BASIC DESIGN VARIABLES ******
----------------------------------------*/
:root {
--wiki-content-heading-font-family: 'Linux Libertine', 'Georgia', 'Times', serif;
--wiki-sidebar-heading-font-family: sans-serif;
--wiki-content-border-radius: 0px;
--wiki-sidebar-border-radius: 0px;
}
/*----------------------------------------
******* END BASIC DESIGN VARIABLES *******
*****************************************/
/*****************************************
****** START BASIC COLOR VARIABLES *******
----------------------------------------*/
:root,
/* Begin light styles, delete from here to "end light styles" if you don't want your wiki to support any light themes (remove from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=light, */
/* individual themes are prefixed with .theme- instead */
.view-light {
/**********************
* Probably edit these * [ LIGHT VIEW ]
***********************/
--wiki-body-background-color: #F6F6F6;
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-content-background-color: #ffffff;
--wiki-content-background-opacity: 100%;
--wiki-content-border-color: #a7d7f9;
--wiki-content-link-color: #0645ad; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ LIGHT VIEW ] */
--wiki-accent-color: #3366cc;
--wiki-accent-label-color: #ffffff;
--wiki-accent-link-color: #D5FB51;
--wiki-icon-to-link-filter: invert(20%) sepia(93%) saturate(2141%) hue-rotate(210deg) brightness(83%) contrast(103%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* end light styles */
/* Begin dark styles, delete from here to "end dark styles" if you don't want your wiki to support any dark themes (remove it from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=dark, */
/* individual themes are prefixed with .theme- instead */
.view-dark {
/**********************
* Probably edit these * [ DARK VIEW ]
***********************/
--wiki-body-background-color: #171717;
--wiki-body-background-image: url(filepath://Site-background-dark.jpg);
--wiki-content-background-color: #202020;
--wiki-content-background-opacity: 90%;
/* DEFAULT: --wiki-content-border-color: #991A51; */
--wiki-content-border-color: hsl(0deg 0% 60%);
--wiki-content-link-color: #6d8afb; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ DARK VIEW ] */
/* DEFAULT: --wiki-accent-color: #ff4d9d; */
--wiki-accent-color: hsl(0deg 0% 75%);
--wiki-accent-label-color: #000;
--wiki-accent-link-color: #1e1e43;
--wiki-icon-to-link-filter: invert(60%) sepia(70%) saturate(3715%) hue-rotate(206deg) brightness(101%) contrast(97%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* End dark styles */
/*----------------------------------------
******* END BASIC COLOR VARIABLES ********
*****************************************/
/*****************************************
**** START ADVANCED COLOR VARIABLES ******
----------------------------------------*/
:root,
.view-light {
/*******************
* Maybe edit these * [ LIGHT VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #111111;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #ba0000;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ LIGHT VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ LIGHT VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #bf0017;
--wiki-warning-color: #b05f30;
--wiki-success-color: #0c742f;
/**/
/***********************************
* Likely do not need to edit these * [ LIGHT VIEW ]
************************************/
--wiki-body-dynamic-color: #000000;
--wiki-body-dynamic-color--inverted: #ffffff;
--wiki-body-dynamic-color--secondary: #333333;
--wiki-body-dynamic-color--secondary--inverted: #cccccc;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #ffffff;
--wiki-content-dynamic-color: #000000;
--wiki-content-dynamic-color--inverted: #ffffff;
--wiki-content-dynamic-color--secondary: #333333;
--wiki-content-dynamic-color--secondary--inverted: #cccccc;
/* [ LIGHT VIEW ] */
--wiki-alert-label-color: #ffffff;
--wiki-warning-label-color: #ffffff;
--wiki-success-label-color: #ffffff;
--wiki-icon-general-filter: ; /* do not set this to none, ignore the "unexpected token" error */
/**/
}
.view-dark {
/*******************
* Maybe edit these * [ DARK VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #ededed;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #FC5B4F;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ DARK VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ DARK VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #ff576a;
--wiki-warning-color: #cf721c;
--wiki-success-color: #13aa45;
/**/
/***********************************
* Likely do not need to edit these * [ DARK VIEW ]
************************************/
--wiki-body-dynamic-color: #ffffff;
--wiki-body-dynamic-color--inverted: #000000;
--wiki-body-dynamic-color--secondary: #cccccc;
--wiki-body-dynamic-color--secondary--inverted: #333333;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #000;
--wiki-content-dynamic-color: #ffffff;
--wiki-content-dynamic-color--inverted: #000000;
--wiki-content-dynamic-color--secondary: #cccccc;
--wiki-content-dynamic-color--secondary--inverted: #333333;
/* [ DARK VIEW ] */
--wiki-alert-label-color: #000000;
--wiki-warning-label-color: #000000;
--wiki-success-label-color: #000000;
--wiki-icon-general-filter: invert(100%);
}
/*----------------------------------------
***** END ADVANCED COLOR VARIABLES *******
*****************************************/
/*****************************************
**** START ADVANCED DESIGN VARIABLES *****
----------------------------------------*/
:root {
/***********************
start logo position
----------------------*/
--wiki-is-top-logo: 0; /* 1 = center logo at the top of the page; 0 = logo at the top left of the page */
--wiki-logo-file-width: 160; /* Width of the image file in px. Put a number without the letters `px`. */
--wiki-logo-file-height: 160; /* Height of the image file in px. Put a number without the letters `px`. */
--wiki-logo-height: calc(var(--wiki-logo-file-height)*1px); /* Valid only when --wiki-is-top-logo is 1. The height the logo should be shown */
--wiki-logo-margin: 15px; /* the width of margin below the logo. When --wiki-is-top-logo is 1, this is also the default value of --wiki-top-spacing */
/*-----------------------
end logo position
***********************/
--wiki-is-navigation-inside-content: 0; /* 0 = default navigation tabs layout; 1 = navigation tabs inside content box */
--wiki-body-font-family: sans-serif;
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family); /* only apply to the main title of article */
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-width: 1px;
--wiki-sidebar-width: 10em; /* width of sidebar(#mw-panel) */
--wiki-sidebar-portal-spacing: 0px;
--wiki-sidebar-border-width: var(--wiki-content-border-width);
--wiki-navigation-border-radius: 0px; /* border radius of tabs */
/*******************
* Maybe edit these * [ DESIGN ]
********************/
--wiki-logo-filter: none;
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-top-radius: var(--wiki-content-border-radius);
--wiki-content-border-style: solid;
--wiki-content-border-image: none;
--wiki-content-backdrop-filter: none;
--wiki-page-content-max-width: 9999px; /* max width of sidebar+gap+content, must be a length value. A huge value can be used to indicate no limit, e.g. 99999px */
--wiki-gap-between-sidebar-and-content: 0.5em; /* gap between sidebar(#mw-panel) and content(#content) */
--wiki-sidebar-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-heading-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-margin: 0.5em;
--wiki-sidebar-list-item-padding: 0.25em 0.25rem;
--wiki-sidebar-list-padding: 0.25rem;
--wiki-sidebar-list-item-background--hover: none; /* background of hover item */
--wiki-navigation-font-size: 0.8125em; /* please use em or rem for this */
--wiki-navigation-height: 2.75rem; /* height of navigation area,include spacing above tabs */
--wiki-navigation-left-spacing: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-radius) + var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-right-spacing: calc( var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-box-background-color: var(--wiki-content-background-color);
--wiki-navigation-box-background-opacity: calc(var(--wiki-content-background-opacity)*0.8*var(--wiki-is-navigation-inside-content));
--wiki-navigation-box-background: color-mix(in srgb, var(--wiki-navigation-box-background-color) var(--wiki-navigation-box-background-opacity), transparent); /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-border-image: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-backdrop-filter: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-selected-backdrop-filter: var(--wiki-content-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
--wiki-navigation-backdrop-filter: var(--wiki-navigation-selected-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
/* nav tabs style. The vector gradient is default.
* If you want to customize the style of tabs, it's easier to start with the following settings:
* --wiki-navigation-background-image: none;
* --wiki-navigation-selected-background-image: none;
* --wiki-navigation-selected-border-width: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-width) + var(--wiki-is-navigation-inside-content) * 1px );
* --wiki-navigation-selected-border-bottom-background: none;
* --wiki-navigation-tab-spacing: 0.25em;
* --wiki-navigation-tab-padding-top: 0.5em;
* --wiki-navigation-tab-padding-bottom: 0.5em;
*/
--wiki-navigation-tab-spacing: -1px; /* width of the space between tabs, can be a negative number, in which case adjacent tabs will overlap */
--wiki-navigation-tab-padding-top: 1.25em;
--wiki-navigation-tab-padding-x: 0.75em;
--wiki-navigation-tab-padding-bottom: 4px;
--wiki-navigation-selected-border-width: 0px; /* border width of selected tabs */
--wiki-navigation-border-width: var(--wiki-navigation-selected-border-width); /* border width of normal tabs */
--wiki-navigation-border-image: none;
--wiki-navigation-selected-border-image: var(--wiki-navigation-border-image);
--wiki-navigation-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to top,var(--wiki-navigation-background-color) 0,var(--wiki-navigation-selected-background-color) 100%);
--wiki-navigation-background-repeat: no-repeat, no-repeat, repeat-x;
--wiki-navigation-background-position: left bottom, right bottom, left bottom;
--wiki-navigation-background-size: 1px 100%, 1px 100%, 100%;
--wiki-navigation-selected-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%);
--wiki-navigation-selected-background-repeat: no-repeat, no-repeat;
--wiki-navigation-selected-background-position: left bottom, right bottom;
--wiki-navigation-selected-background-size: 1px 100%, 1px 100%;
--wiki-navigation-selected-border-bottom-background: linear-gradient(to right, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px), linear-gradient(to left, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px);
/* affects the dropdown menu under More */
--wiki-navigation-dropdown-text-color: var(--wiki-navigation-text-color);
--wiki-navigation-dropdown-text-color--hover: var(--wiki-navigation-dropdown-text-color);
--wiki-navigation-dropdown-font-size: var(--wiki-navigation-font-size); /* please use em or rem for this */
--wiki-navigation-dropdown-border-width: 1px;
--wiki-navigation-dropdown-border-radius: var(--wiki-navigation-border-radius);
--wiki-navigation-dropdown-padding: 0.25em; /* padding of the dropdown menu box */
--wiki-navigation-dropdown-item-padding: 0.625em; /* padding of each dropdown menu items */
--wiki-navigation-dropdown-item-background--hover: none; /* background of hover item */
--wiki-navigation-dropdown-border-image: none;
--wiki-navigation-dropdown-backdrop-filter: none;
--wiki-navigation-dropdown-box-shadow: none; /* box shadow */
/* styles of the footer */
--wiki-spacing-before-footer: 0px;
--wiki-footer-border-image: none;
/* padding on body element */
--wiki-top-spacing: calc(var(--wiki-is-top-logo)*var(--wiki-logo-margin) + (1 - var(--wiki-is-top-logo))*1em); /* extra spacing below wiki.gg netbar */
--wiki-left-spacing: 0.5em;
--wiki-right-spacing: 1em;
--wiki-bottom-spacing: 2em;
/* end design variables */
}
/*----------------------------------------
***** END ADVANCED DESIGN VARIABLES ******
*****************************************/
/*******************************
**** START SHARED VARIABLES ****
**** tl;dr: don't edit this ****
********************************/
/*
These variables are rarely touched, usually inherit other variables, and are shared on all themes.
In 99% of cases none of these are ever edited, and you should only be doing so if you have a very clear vision,
understand what you are doing, and *know* that what you are trying to do is not accomplished by changing
another variable in the above sections.
Since these are by default shared across all themes, if you support multiple themes you'll probably want to
separate the variables you want to modify here into .view-x blocks like above. If you don't understand
what that means or how to do that then you probably shouldn't be modifying this section.
*/
:root {
--wiki-content-border-bottom-width: var(--wiki-content-border-width);
--wiki-content-border-bottom-style: var(--wiki-content-border-style);
--wiki-content-border-bottom-color: var(--wiki-content-border-color);
--wiki-content-text-mix-color: color-mix(in srgb, var(--wiki-content-background-color), var(--wiki-content-text-color) 62%);
--wiki-content-text-mix-color-95: color-mix(in srgb, var(--wiki-content-background-color) 95%, var(--wiki-content-text-color));
--wiki-content-text-color--hover: var(--wiki-content-text-color);
/* heading */
--wiki-content-heading-border-bottom-width: 1px;
--wiki-content-heading-border-style: solid;
--wiki-content-heading-font-weight: normal;
--wiki-content-heading-font-style: normal;
--wiki-content-heading-text-transform: none;
--wiki-content-heading-line-height: normal;
--wiki-content-heading-text-shadow: none;
/* first heading (h1) */
--wiki-content-firstheading-border-bottom-width: var(--wiki-content-heading-border-bottom-width);
--wiki-content-firstheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-firstheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family);
--wiki-content-firstheading-font-weight: var(--wiki-content-heading-font-weight);
--wiki-content-firstheading-font-style: var(--wiki-content-heading-font-style);
--wiki-content-firstheading-text-transform: var(--wiki-content-heading-text-transform);
--wiki-content-firstheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-firstheading-color: var(--wiki-content-heading-color);
--wiki-content-firstheading-text-shadow: none;
/* sub-heading (h3, h4, h5, h6) */
--wiki-content-subheading-border-bottom-width: 0px;
--wiki-content-subheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-subheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-subheading-font-family: var(--wiki-body-font-family);
--wiki-content-subheading-font-weight: bold;
--wiki-content-subheading-font-style: normal;
--wiki-content-subheading-text-transform: none;
--wiki-content-subheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-subheading-color: var(--wiki-content-heading-color);
--wiki-content-subheading-text-shadow: none;
/* heading size */
--wiki-content-firstheading-font-size: 1.8em;
--wiki-content-heading-h2-font-size: 1.5em;
--wiki-content-heading-h3-font-size: 1.2em;
--wiki-content-heading-h4-font-size: 114%;
--wiki-content-heading-h5-font-size: 108%;
--wiki-content-heading-h6-font-size: 100%;
--wiki-content-toc-background: var(--wiki-content-background-color--secondary);
--wiki-content-toc-border-width: 1px;
--wiki-content-toc-border-style: solid;
--wiki-content-toc-border-color: var(--wiki-content-border-color);
--wiki-content-toc-border-radius: 0px;
--wiki-content-toc-border-image: none;
--wiki-content-toc-box-shadow: 0 0.1em 0.2em #000000;
--wiki-content-catlinks-background: var(--wiki-content-background-color--secondary);
--wiki-content-catlinks-border-width: 1px;
--wiki-content-catlinks-border-style: solid;
--wiki-content-catlinks-border-color: var(--wiki-content-border-color);
--wiki-content-catlinks-border-radius: 0px;
--wiki-content-catlinks-border-image: none;
--wiki-content-catlinks-box-shadow: none;
--wiki-content-filetoc-background: var(--wiki-content-background-color--secondary);
--wiki-content-filetoc-border-width: 1px;
--wiki-content-filetoc-border-style: solid;
--wiki-content-filetoc-border-color: var(--wiki-content-border-color);
--wiki-content-filetoc-border-radius: 0px;
--wiki-content-filetoc-border-image: none;
--wiki-content-filetoc-box-shadow: none;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
--wiki-sidebar-padding: 0px;
--wiki-sidebar-background-color: var(--wiki-content-background-color);
--wiki-sidebar-background-opacity: var(--wiki-content-background-opacity);
--wiki-sidebar-background-image: none;
--wiki-sidebar-background-position: center;
--wiki-sidebar-background-repeat: repeat;
--wiki-sidebar-background-size: auto;
--wiki-sidebar-filter: none;
--wiki-sidebar-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-sidebar-border-color: var(--wiki-content-border-color);
--wiki-sidebar-border-style: solid;
--wiki-sidebar-border-image: none;
--wiki-sidebar-link-color: var(--wiki-content-link-color);
--wiki-sidebar-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-sidebar-heading-color: var(--wiki-content-heading-color);
--wiki-sidebar-heading-font-weight: normal;
--wiki-sidebar-heading-font-style: normal;
--wiki-sidebar-heading-text-transform: none;
--wiki-sidebar-heading-line-height: normal;
--wiki-sidebar-heading-padding: 0.5rem 0.25rem 0.5rem 0.5rem;
--wiki-sidebar-heading-margin: 0px 0px -0.5rem 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-text-shadow: none;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-icon-to-link-filter: var(--wiki-icon-to-link-filter);
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-box-padding: 0px;
--wiki-sidebar-box-background: none;
--wiki-sidebar-box-border: 0px;
--wiki-sidebar-box-border-image: none;
--wiki-accent-color--hover: color-mix(in srgb, var(--wiki-accent-color) 90%, var(--wiki-accent-label-color));
--wiki-footer-border-width: var(--wiki-content-border-width);
--wiki-footer-border-style: var(--wiki-content-border-style);
--wiki-footer-border-color: var(--wiki-content-border-color);
--wiki-footer-background-color: var(--wiki-content-background-color);
--wiki-footer-background-opacity: var(--wiki-content-background-opacity);
--wiki-footer-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-footer-text-color: var(--wiki-content-text-color);
--wiki-footer-link-color: var(--wiki-content-link-color);
--wiki-footer-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-footer-border-radius: var(--wiki-content-border-radius);
--wiki-navigation-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-background-color--hover: var(--wiki-navigation-background-color);
--wiki-navigation-background-opacity--hover: var(--wiki-navigation-background-opacity);
--wiki-navigation-background-image--hover: var(--wiki-navigation-background-image);
--wiki-navigation-background-position--hover: var(--wiki-navigation-background-position);
--wiki-navigation-background-repeat--hover: var(--wiki-navigation-background-repeat);
--wiki-navigation-background-size--hover: var(--wiki-navigation-background-size);
--wiki-navigation-text-color--hover: var(--wiki-content-link-color--hover);
--wiki-navigation-transform--hover: none;
--wiki-navigation-selected-border-style: solid;
--wiki-navigation-selected-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-border-style: solid;
--wiki-navigation-border-color--hover: var(--wiki-navigation-border-color);
--wiki-navigation-border-image--hover: var(--wiki-navigation-border-image);
--wiki-navigation-border-bottom-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-border-bottom-style: var(--wiki-navigation-selected-border-style);
--wiki-navigation-border-bottom-width: calc(var(--wiki-is-navigation-inside-content, 0) * var(--wiki-navigation-selected-border-width, 1px) + (1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-width, 1px));
--wiki-navigation-icon-size: 1em;
--wiki-navigation-tab-padding-x--icon: var(--wiki-navigation-tab-padding-x);
--wiki-navigation-bottom-spacing: 0px; /* If you change this to greater than 0px, you should usually change the value of --wiki-navigation-selected-border-bottom-background to var(--wiki-navigation-border-bottom-color) */
--wiki-navigation-dropdown-background-color: var(--wiki-navigation-selected-background-color);
--wiki-navigation-dropdown-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-dropdown-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-dropdown-offset: 0px; /* vertical offset */
--wiki-navigation-search-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-search-background-image: none;
--wiki-navigation-search-background-position: 0;
--wiki-navigation-search-background-size: auto;
--wiki-navigation-search-background-repeat: repeat;
--wiki-navigation-search-backdrop-filter: none;
--wiki-navigation-search-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-search-border-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-border-style: solid;
--wiki-navigation-search-border-width: 1px;
--wiki-navigation-search-border-radius: 2px;
--wiki-navigation-search-border-image: none;
--wiki-navigation-search-border-image--hover: var(--wiki-navigation-search-border-image);
--wiki-navigation-search-box-shadow: none;
--wiki-navigation-search-box-shadow--hover: var(--wiki-navigation-search-box-shadow);
--wiki-navigation-search-text-color: var(--wiki-content-text-color);
--wiki-navigation-search-font-size: var(--wiki-navigation-font-size);
--wiki-navigation-search-height: 2em;
--wiki-navigation-search-button-color: currentColor;
--wiki-navigation-search-button-color--hover: var(--wiki-navigation-search-button-color);
--wiki-navigation-search-button-color-opacity: 80%;
--wiki-navigation-search-button-color-opacity--hover: 95%;
--wiki-navigation-search-bottom-spacing: 3px;
--wiki-navigation-search-highlight-background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
--wiki-navigation-gap-between-left-and-right: calc(max(0px, var(--wiki-navigation-tab-spacing))); /* minimum width between #left-navigation and #right-navigation before tabs start to collapse */
}
/*** mobile adjustments ***/
@media screen and (max-width: 720px) {
body.has-vector-mobile-menu{
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-margin: 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-margin: 0px 0px -0.5em 0px;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-background-opacity: 100%;
--wiki-navigation-search-border-width: 1px;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
}
}
/*****************************
**** END SHARED VARIABLES ****
******************************/
/******************************************************************************************
********************************* End user-edit variables *********************************
******************************************************************************************/
/******************************
* Fallback for older browsers *
* DONT EDIT THIS *
*******************************/
@supports not (color:color-mix(in srgb, #000, transparent)) {
.view-dark,
.view-light,
:root {
--wiki-content-text-mix-color: var(--wiki-content-text-color);
--wiki-content-text-mix-color-95: var(--wiki-content-background-color);
--wiki-content-background-color--secondary: var(--wiki-content-dynamic-color--secondary--inverted);
--wiki-content-border-color--secondary: var(--wiki-content-border-color);
--wiki-content-border-color--accent: var(--wiki-accent-color);
--wiki-accent-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-highlight-background-color: transparent;
}
}
/*****************************
* End older browser fallback *
******************************/
/*****************************
* PortableInfoboxes *
******************************/
:root {
--pi-background: var(--wiki-content-background-color);
--pi-secondary-background: var(--wiki-accent-color);
--pi-secondary-background-label: var(--wiki-accent-label-color);
--pi-border-color: color-mix(in srgb, var(--pi-secondary-background) 50%, transparent);
}
.portable-infobox .pi-title,
.portable-infobox .pi-header {
text-align: center;
font-size: 1.5em;
background: color-mix(in srgb, var(--pi-secondary-background) 75%, transparent);
color: var(--pi-secondary-background-label);
}
.portable-infobox .pi-data,
.portable-infobox .pi-group {
background: var(--wiki-content-background-color--secondary);
}
.portable-infobox .pi-image {
padding: 8px;
}
.pi-image-thumbnail {
max-width: 100%;
}
.pi-caption {
color: var(--wiki-content-text-mix-color);
}
.pi-section-navigation .pi-section-tab.pi-section-active,
.pi-section-navigation .pi-section-tab.current,
.pi-media-collection .pi-tab-link.current {
background: var(--pi-secondary-background);
color: var(--pi-secondary-background-label);
}
.pi-collapse > .pi-item:first-child {
cursor: pointer;
}
/* overqualify these to overwrite normal content heading styles */
.mw-body .portable-infobox h2,
.mw-body .portable-infobox h3 {
border-bottom: 0;
font-family: inherit;
font-weight: 700;
margin: 0;
}
/*****************************
* End PortableInfoboxes *
******************************/
/*******************
* Main page layout *
********************/
#mp-container {
display: grid;
gap: 10px;
}
@media screen and (max-width: 990px) {
/* for mobile screens */
#mp-container {
grid-template-areas:var(--main-page-layout--mobile);
grid-template-columns:var(--main-page-layout-columns--mobile, 100%);
}
.mp-box.mp-hide-on-mobile {
display: none;
}
}
@media screen and (min-width: 990px) and (max-width: 1350px) {
/* for narrow screens, between 990px and 1350px */
#mp-container {
grid-template-areas:var(--main-page-layout--tablet);
grid-template-columns:var(--main-page-layout-columns--tablet, 1fr 1fr);
}
.mp-box.mp-hide-on-tablet {
display: none;
}
}
@media screen and (min-width: 1350px) {
/* for all other screens, 1350px and wider */
#mp-container {
grid-template-areas:var(--main-page-layout--desktop);
grid-template-columns:var(--main-page-layout-columns--desktop, 2fr 1fr 2fr);
}
.mp-box.mp-hide-on-desktop {
display: none;
}
}
.mp-box {
position: relative;
display: flex;
flex-flow: column nowrap;
width: 100%;
box-sizing: border-box;
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 25%, transparent);
border: 1px solid var(--wiki-content-border-color);
padding: 0px;
}
.mp-body {
height: 100%;
display: flex;
padding: 0.5em;
flex-flow: column nowrap;
}
.mp-box.centered-content .mp-body {
height: 100%;
display: flex;
flex-flow: column nowrap;
justify-content: space-evenly;
}
.mp-box.has-floating-image {
display: block;
}
.mp-box.has-floating-image .mp-body {
height: unset;
display: block;
}
/* overqualified to override normal heading styles */
.mw-body .mp-box h2 {
text-align: center;
font-weight: bold;
font-family: var(--wiki-content-heading-font-family);
overflow: initial;
border-bottom: 1px solid var(--wiki-content-border-color);
font-size: 150%;
margin: 0;
padding: 5px 0;
color: var(--wiki-content-heading-color);
}
#mp-box-welcome {
text-align: center;
position: relative;
overflow: hidden;
}
#mp-box-welcome h2 {
font-size: 200%;
}
#mp-welcome {
display: flex;
flex-flow: column nowrap;
position: relative;
height: 100%;
z-index: 2;
box-sizing: border-box;
}
#mp-welcome .welcome-subtitle {
height: 100%;
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 85%, transparent);
padding: 0.5em;
}
#mp-banner {
position: absolute;
width: 100%;
height: 100%;
filter: blur(5px);
z-index: -1;
background: url(/images/e/e0/MP_banner.jpg);
background-size: cover;
background-repeat: no-repeat;
background-position: top center;
}
.view-dark #mp-banner {
filter: blur(5px) brightness(50%);
}
.view-light #mp-banner {
filter: blur(5px) contrast(50%);
}
/* [[Template:MP_link]] */
.mp-links {
--gap: 10px;
}
.mp-links > ul {
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin: 2px;
gap: var(--gap);
}
.mp-links > ul > li {
display: flex;
flex-flow: column nowrap;
align-items: stretch;
text-align: center;
box-sizing: border-box;
flex: max(calc(50% - var(--gap)), 5em) 1 1;
outline: 1px solid var(--wiki-content-link-color);
transition: 0.1s ease-in;
}
.mp-links > ul > li:hover {
background-color: color-mix(in srgb, var(--wiki-content-link-color) 20%, transparent);
}
.mp-links.columns-1 > ul > li {flex: max(calc(100% - var(--gap)), 5em) 1 1;}
.mp-links.columns-2 > ul > li {flex: max(calc(50% - var(--gap)), 5em) 1 1;}
.mp-links.columns-3 > ul > li {flex: max(calc((100% / 3) - var(--gap)), 5em) 1 1;}
.mp-links.columns-4 > ul > li {flex: max(calc(25% - var(--gap)), 5em) 1 1;}
.mp-links.columns-5 > ul > li {flex: max(calc(20% - var(--gap)), 5em) 1 1;}
.mp-links.columns-6 > ul > li {flex: max(calc((100% / 6) - var(--gap)), 5em) 1 1;}
.mp-links.columns-7 > ul > li {flex: max(calc((100% / 7) - var(--gap)), 5em) 1 1;}
.mp-links.columns-8 > ul > li {flex: max(calc((100% / 8) - var(--gap)), 5em) 1 1;}
.mp-links.columns-max > ul > li {flex: max(calc(0% - var(--gap)), 5em) 1 1;}
.mp-links > ul > li:hover a {
text-decoration: underline;
}
.mp-links > ul > li > a {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
flex: 1 1 auto;
box-sizing: border-box;
padding: 5px;
}
.mp-links > ul > li > a:first-child {
height: 100%;
}
.mp-links > ul > li > a:last-child:not(:first-child) {
height: unset;
}
.mp-links.stretch,
.mp-links.stretch > ul {
height: 100%;
}
.mp-links.side-image li {
flex-flow: row nowrap;
}
.mp-links.plain > ul > li {
outline-color: transparent;
}
/***********************
* End main page layout *
************************/
/*********************************************************************************************************************
* Semantically-correct horizontal lists (for Module:Navbox, and they're more machine-readable than {{*}}-formatting) *
**********************************************************************************************************************/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so: */
.hlist dt:not(:last-child)::after {
content: ":\20";
}
.hlist dd:not(:last-child)::after,
.hlist li:not(:last-child)::after {
/* "space, Middle Dot, space"
We use unicode numbers instead of the raw characters due to a Firefox encoding bug on unicode characters.
The space is also encoded because raw spaces combined with a unicode number strips the spaces under some conditions such as single-line lists */
/* content: "\20\00B7\20"; font-weight: bold; */
/* "space • space"
There may (and likely) be an extra whitespace between <li>s,
therefore we have to use a space character as last character of this sequence.
By this way, the last space and the next whitespce will collapse as a single space,
to make the whitespace on both sides of the middle dot the same width.
*/
content: "\20\A0\2022\A0\20";
font-weight: inherit;
}
/* Add parentheses around nested lists */
.hlist dd ol::before,
.hlist dd ul::before,
.hlist dd dl::before,
.hlist dt ol::before,
.hlist dt ul::before,
.hlist dt dl::before,
.hlist li ol::before,
.hlist li ul::before,
.hlist li dl::before {
content: "\20(";
font-weight: inherit;
}
.hlist dd ol::after,
.hlist dd ul::after,
.hlist dd dl::after,
.hlist dt ol::after,
.hlist dt ul::after,
.hlist dt dl::after,
.hlist li ol::after,
.hlist li ul::after,
.hlist li dl::after {
content: ")";
font-weight: inherit;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) ".\20";
}
/* Progressive enhancement:
* try to make the dot always follow the list item in same line
*/
.hlist :is(li,dt,dd):not(:has(:is(li,dt,dd))) {
display: inline-block;
}
/********************************************
* End semantically-correct horizontal lists *
*********************************************/
/*** Miscellaneous ***/
.responsive-image {
max-width: 100%;
height: auto;
}
.view-dark .invert-on-dark,
.view-light .invert-on-light {
filter: invert(100%);
}
.pixelated {
image-rendering: pixelated;
}
@media screen and (min-width: 720px) {
.mobileonly {
display: none;
}
}
@media screen and (max-width: 720px) {
.nomobile {
display: none;
}
}
/*** Utility classes for standard MW galleries ***/
/* it's important that spaced comes before centered in the sheet */
.gallery.gallery.gallery.spaced { /* this selector looks ridiculous but is actually part of stock Vector and therefore a necessary override */
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin-left: unset;
}
.gallery.centered {
text-align: center;
}
/**************************
* Start Modular Templates *
**************************/
/********* [[Template:Ambox]] *********/
.ambox {
--ambox-color: var(--wiki-accent-color);
border: 1px solid var(--wiki-content-border-color);
border-left: 10px solid var(--ambox-color);
border-radius: 2px;
display: flex;
align-items: center;
gap: .6em;
margin: 1em 0;
padding: 3px .6em;
background-color: var(--wiki-content-background-color--secondary);
box-shadow: 2px 2px 5px 0px #0002;
}
@media (min-width: 720px) {
.ambox {
margin-inline: 10%;
}
}
.ambox.tiny {
padding: .04rem .5em;
margin-inline: 0;
width: fit-content;
}
.ambox + .ambox {
margin-top: -.6em;
}
.ambox-content {
flex: 1;
}
.ambox-content p {
margin: .15em 0;
}
.ambox-title {
font-weight: bold;
}
/********* [[Template:Hatnote]] *********/
.hatnote {
padding: 1px 0 1px 1.6em;
margin-bottom: 0.5em;
font-style: italic;
border-top: 1px solid var(--wiki-content-border-color--secondary);
border-bottom: 1px solid var(--wiki-content-border-color--secondary);
}
.hatnote.icon {
padding-left: 0;
}
/********* [[Template:Spoiler]] *********/
.spoiler-content {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 50%, transparent);
transition: all 0.3s;
cursor: pointer;
overflow: auto;
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.spoiler-content {
background-color: var(--wiki-content-dynamic-color--secondary);
}
}
.spoiler-content > * {
pointer-events: none;
opacity: 0;
transition: all 0.3s;
}
.spoiler-content.show {
background-color: transparent;
}
.spoiler-content.show > * {
pointer-events: unset;
opacity: 1;
}
/********* [[Template:Link icon]] *********/
.link-icon {
--link-icon-line-height: 1.5em;
--link-icon-size: 1.5em;
display: inline-flex;
align-items: center;
height: var(--link-icon-line-height);
vertical-align: bottom;
}
.link-icon .regular {
align-self: center;
}
.link-icon .regular a {
display: flex;
}
.link-icon .regular img {
height: var(--link-icon-size);
max-width: var(--link-icon-size);
}
.link-icon .fallback {
outline: 1px solid var(--wiki-content-text-color);
border-radius: 50%;
text-align: center;
width: var(--link-icon-size);
line-height: var(--link-icon-size);
}
.link-icon.notext,
.link-icon.notext .fallback {
display: inline-block;
}
/********* [[Template:Quote]] *********/
.quote {
background: var(--wiki-content-background-color--secondary);
border-radius: 5px;
border: 2px solid var(--wiki-content-border-color);
margin: .5em 0;
padding: .5em;
overflow-y: hidden;
}
.quote .block {
display: block;
}
.quote .title {
font-size: large;
font-weight: bold;
}
.quote .content {
font-style: italic;
}
.quote .author {
font-weight: bold;
text-align: end;
}
.quote .marks-wrapper {
display: flex;
gap: 5px;
}
.quote .marks-wrapper::before,
.quote .marks-wrapper::after {
font-size: 100px;
line-height: 0px;
}
.quote .marks-wrapper::before {
content: "\201C";
margin-top: 40px;
}
.quote .marks-wrapper::after {
content: "\201D";
align-self: end;
margin-bottom: -10px;
}
.client-js .mw-charinsert-item {
display: none;
}
/************************
* End Modular Templates *
*************************/
/*****************************
* Used by [[Template:Color]] *
******************************/
.color__splotch {
display: inline-block;
height: 1em;
width: 1em;
box-sizing: border-box;
vertical-align: text-top;
border-radius: 50%;
border: 1px solid var(--wiki-content-text-color);
}
/*********************
* End Template:Color *
**********************/
/*********************************
* Used by [[Template:TOC limit]] *
**********************************/
.toclimit-2 .toclevel-1 ul,
.toclimit-3 .toclevel-2 ul,
.toclimit-4 .toclevel-3 ul,
.toclimit-5 .toclevel-4 ul,
.toclimit-6 .toclevel-5 ul,
.toclimit-7 .toclevel-6 ul {
display: none;
}
/*************************
* End Template:TOC limit *
**************************/
/*********************************
* Used by [[Template:TOC right]] *
**********************************/
@media all and (min-width: 720px) {
.tocright {
float: right;
clear: right;
margin: 0 0 0.5em 1em;
}
}
/*************************
* End Template:TOC right *
**************************/
23b1aa2ed7d9d5de6f1c3b3f7f2d01379b0f3907
1331
1330
2025-08-23T16:49:46Z
Sharparam
284703
Adjust content border color for dark theme
css
text/css
/* CSS placed here will be applied to all skins */
/******************************************************************************************
********************************* Start user-edit variables *******************************
******************************************************************************************/
/*****************************************
****** START BASIC DESIGN VARIABLES ******
----------------------------------------*/
:root {
--wiki-content-heading-font-family: 'Linux Libertine', 'Georgia', 'Times', serif;
--wiki-sidebar-heading-font-family: sans-serif;
--wiki-content-border-radius: 0px;
--wiki-sidebar-border-radius: 0px;
}
/*----------------------------------------
******* END BASIC DESIGN VARIABLES *******
*****************************************/
/*****************************************
****** START BASIC COLOR VARIABLES *******
----------------------------------------*/
:root,
/* Begin light styles, delete from here to "end light styles" if you don't want your wiki to support any light themes (remove from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=light, */
/* individual themes are prefixed with .theme- instead */
.view-light {
/**********************
* Probably edit these * [ LIGHT VIEW ]
***********************/
--wiki-body-background-color: #F6F6F6;
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-content-background-color: #ffffff;
--wiki-content-background-opacity: 100%;
--wiki-content-border-color: #a7d7f9;
--wiki-content-link-color: #0645ad; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ LIGHT VIEW ] */
--wiki-accent-color: #3366cc;
--wiki-accent-label-color: #ffffff;
--wiki-accent-link-color: #D5FB51;
--wiki-icon-to-link-filter: invert(20%) sepia(93%) saturate(2141%) hue-rotate(210deg) brightness(83%) contrast(103%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* end light styles */
/* Begin dark styles, delete from here to "end dark styles" if you don't want your wiki to support any dark themes (remove it from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=dark, */
/* individual themes are prefixed with .theme- instead */
.view-dark {
/**********************
* Probably edit these * [ DARK VIEW ]
***********************/
--wiki-body-background-color: #171717;
--wiki-body-background-image: url(filepath://Site-background-dark.jpg);
--wiki-content-background-color: #202020;
--wiki-content-background-opacity: 90%;
/* DEFAULT: --wiki-content-border-color: #991A51; */
--wiki-content-border-color: hsl(0deg 0% 30%);
--wiki-content-link-color: #6d8afb; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ DARK VIEW ] */
/* DEFAULT: --wiki-accent-color: #ff4d9d; */
--wiki-accent-color: hsl(0deg 0% 75%);
--wiki-accent-label-color: #000;
--wiki-accent-link-color: #1e1e43;
--wiki-icon-to-link-filter: invert(60%) sepia(70%) saturate(3715%) hue-rotate(206deg) brightness(101%) contrast(97%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* End dark styles */
/*----------------------------------------
******* END BASIC COLOR VARIABLES ********
*****************************************/
/*****************************************
**** START ADVANCED COLOR VARIABLES ******
----------------------------------------*/
:root,
.view-light {
/*******************
* Maybe edit these * [ LIGHT VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #111111;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #ba0000;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ LIGHT VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ LIGHT VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #bf0017;
--wiki-warning-color: #b05f30;
--wiki-success-color: #0c742f;
/**/
/***********************************
* Likely do not need to edit these * [ LIGHT VIEW ]
************************************/
--wiki-body-dynamic-color: #000000;
--wiki-body-dynamic-color--inverted: #ffffff;
--wiki-body-dynamic-color--secondary: #333333;
--wiki-body-dynamic-color--secondary--inverted: #cccccc;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #ffffff;
--wiki-content-dynamic-color: #000000;
--wiki-content-dynamic-color--inverted: #ffffff;
--wiki-content-dynamic-color--secondary: #333333;
--wiki-content-dynamic-color--secondary--inverted: #cccccc;
/* [ LIGHT VIEW ] */
--wiki-alert-label-color: #ffffff;
--wiki-warning-label-color: #ffffff;
--wiki-success-label-color: #ffffff;
--wiki-icon-general-filter: ; /* do not set this to none, ignore the "unexpected token" error */
/**/
}
.view-dark {
/*******************
* Maybe edit these * [ DARK VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #ededed;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #FC5B4F;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ DARK VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ DARK VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #ff576a;
--wiki-warning-color: #cf721c;
--wiki-success-color: #13aa45;
/**/
/***********************************
* Likely do not need to edit these * [ DARK VIEW ]
************************************/
--wiki-body-dynamic-color: #ffffff;
--wiki-body-dynamic-color--inverted: #000000;
--wiki-body-dynamic-color--secondary: #cccccc;
--wiki-body-dynamic-color--secondary--inverted: #333333;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #000;
--wiki-content-dynamic-color: #ffffff;
--wiki-content-dynamic-color--inverted: #000000;
--wiki-content-dynamic-color--secondary: #cccccc;
--wiki-content-dynamic-color--secondary--inverted: #333333;
/* [ DARK VIEW ] */
--wiki-alert-label-color: #000000;
--wiki-warning-label-color: #000000;
--wiki-success-label-color: #000000;
--wiki-icon-general-filter: invert(100%);
}
/*----------------------------------------
***** END ADVANCED COLOR VARIABLES *******
*****************************************/
/*****************************************
**** START ADVANCED DESIGN VARIABLES *****
----------------------------------------*/
:root {
/***********************
start logo position
----------------------*/
--wiki-is-top-logo: 0; /* 1 = center logo at the top of the page; 0 = logo at the top left of the page */
--wiki-logo-file-width: 160; /* Width of the image file in px. Put a number without the letters `px`. */
--wiki-logo-file-height: 160; /* Height of the image file in px. Put a number without the letters `px`. */
--wiki-logo-height: calc(var(--wiki-logo-file-height)*1px); /* Valid only when --wiki-is-top-logo is 1. The height the logo should be shown */
--wiki-logo-margin: 15px; /* the width of margin below the logo. When --wiki-is-top-logo is 1, this is also the default value of --wiki-top-spacing */
/*-----------------------
end logo position
***********************/
--wiki-is-navigation-inside-content: 0; /* 0 = default navigation tabs layout; 1 = navigation tabs inside content box */
--wiki-body-font-family: sans-serif;
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family); /* only apply to the main title of article */
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-width: 1px;
--wiki-sidebar-width: 10em; /* width of sidebar(#mw-panel) */
--wiki-sidebar-portal-spacing: 0px;
--wiki-sidebar-border-width: var(--wiki-content-border-width);
--wiki-navigation-border-radius: 0px; /* border radius of tabs */
/*******************
* Maybe edit these * [ DESIGN ]
********************/
--wiki-logo-filter: none;
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-top-radius: var(--wiki-content-border-radius);
--wiki-content-border-style: solid;
--wiki-content-border-image: none;
--wiki-content-backdrop-filter: none;
--wiki-page-content-max-width: 9999px; /* max width of sidebar+gap+content, must be a length value. A huge value can be used to indicate no limit, e.g. 99999px */
--wiki-gap-between-sidebar-and-content: 0.5em; /* gap between sidebar(#mw-panel) and content(#content) */
--wiki-sidebar-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-heading-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-margin: 0.5em;
--wiki-sidebar-list-item-padding: 0.25em 0.25rem;
--wiki-sidebar-list-padding: 0.25rem;
--wiki-sidebar-list-item-background--hover: none; /* background of hover item */
--wiki-navigation-font-size: 0.8125em; /* please use em or rem for this */
--wiki-navigation-height: 2.75rem; /* height of navigation area,include spacing above tabs */
--wiki-navigation-left-spacing: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-radius) + var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-right-spacing: calc( var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-box-background-color: var(--wiki-content-background-color);
--wiki-navigation-box-background-opacity: calc(var(--wiki-content-background-opacity)*0.8*var(--wiki-is-navigation-inside-content));
--wiki-navigation-box-background: color-mix(in srgb, var(--wiki-navigation-box-background-color) var(--wiki-navigation-box-background-opacity), transparent); /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-border-image: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-backdrop-filter: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-selected-backdrop-filter: var(--wiki-content-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
--wiki-navigation-backdrop-filter: var(--wiki-navigation-selected-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
/* nav tabs style. The vector gradient is default.
* If you want to customize the style of tabs, it's easier to start with the following settings:
* --wiki-navigation-background-image: none;
* --wiki-navigation-selected-background-image: none;
* --wiki-navigation-selected-border-width: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-width) + var(--wiki-is-navigation-inside-content) * 1px );
* --wiki-navigation-selected-border-bottom-background: none;
* --wiki-navigation-tab-spacing: 0.25em;
* --wiki-navigation-tab-padding-top: 0.5em;
* --wiki-navigation-tab-padding-bottom: 0.5em;
*/
--wiki-navigation-tab-spacing: -1px; /* width of the space between tabs, can be a negative number, in which case adjacent tabs will overlap */
--wiki-navigation-tab-padding-top: 1.25em;
--wiki-navigation-tab-padding-x: 0.75em;
--wiki-navigation-tab-padding-bottom: 4px;
--wiki-navigation-selected-border-width: 0px; /* border width of selected tabs */
--wiki-navigation-border-width: var(--wiki-navigation-selected-border-width); /* border width of normal tabs */
--wiki-navigation-border-image: none;
--wiki-navigation-selected-border-image: var(--wiki-navigation-border-image);
--wiki-navigation-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to top,var(--wiki-navigation-background-color) 0,var(--wiki-navigation-selected-background-color) 100%);
--wiki-navigation-background-repeat: no-repeat, no-repeat, repeat-x;
--wiki-navigation-background-position: left bottom, right bottom, left bottom;
--wiki-navigation-background-size: 1px 100%, 1px 100%, 100%;
--wiki-navigation-selected-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%);
--wiki-navigation-selected-background-repeat: no-repeat, no-repeat;
--wiki-navigation-selected-background-position: left bottom, right bottom;
--wiki-navigation-selected-background-size: 1px 100%, 1px 100%;
--wiki-navigation-selected-border-bottom-background: linear-gradient(to right, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px), linear-gradient(to left, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px);
/* affects the dropdown menu under More */
--wiki-navigation-dropdown-text-color: var(--wiki-navigation-text-color);
--wiki-navigation-dropdown-text-color--hover: var(--wiki-navigation-dropdown-text-color);
--wiki-navigation-dropdown-font-size: var(--wiki-navigation-font-size); /* please use em or rem for this */
--wiki-navigation-dropdown-border-width: 1px;
--wiki-navigation-dropdown-border-radius: var(--wiki-navigation-border-radius);
--wiki-navigation-dropdown-padding: 0.25em; /* padding of the dropdown menu box */
--wiki-navigation-dropdown-item-padding: 0.625em; /* padding of each dropdown menu items */
--wiki-navigation-dropdown-item-background--hover: none; /* background of hover item */
--wiki-navigation-dropdown-border-image: none;
--wiki-navigation-dropdown-backdrop-filter: none;
--wiki-navigation-dropdown-box-shadow: none; /* box shadow */
/* styles of the footer */
--wiki-spacing-before-footer: 0px;
--wiki-footer-border-image: none;
/* padding on body element */
--wiki-top-spacing: calc(var(--wiki-is-top-logo)*var(--wiki-logo-margin) + (1 - var(--wiki-is-top-logo))*1em); /* extra spacing below wiki.gg netbar */
--wiki-left-spacing: 0.5em;
--wiki-right-spacing: 1em;
--wiki-bottom-spacing: 2em;
/* end design variables */
}
/*----------------------------------------
***** END ADVANCED DESIGN VARIABLES ******
*****************************************/
/*******************************
**** START SHARED VARIABLES ****
**** tl;dr: don't edit this ****
********************************/
/*
These variables are rarely touched, usually inherit other variables, and are shared on all themes.
In 99% of cases none of these are ever edited, and you should only be doing so if you have a very clear vision,
understand what you are doing, and *know* that what you are trying to do is not accomplished by changing
another variable in the above sections.
Since these are by default shared across all themes, if you support multiple themes you'll probably want to
separate the variables you want to modify here into .view-x blocks like above. If you don't understand
what that means or how to do that then you probably shouldn't be modifying this section.
*/
:root {
--wiki-content-border-bottom-width: var(--wiki-content-border-width);
--wiki-content-border-bottom-style: var(--wiki-content-border-style);
--wiki-content-border-bottom-color: var(--wiki-content-border-color);
--wiki-content-text-mix-color: color-mix(in srgb, var(--wiki-content-background-color), var(--wiki-content-text-color) 62%);
--wiki-content-text-mix-color-95: color-mix(in srgb, var(--wiki-content-background-color) 95%, var(--wiki-content-text-color));
--wiki-content-text-color--hover: var(--wiki-content-text-color);
/* heading */
--wiki-content-heading-border-bottom-width: 1px;
--wiki-content-heading-border-style: solid;
--wiki-content-heading-font-weight: normal;
--wiki-content-heading-font-style: normal;
--wiki-content-heading-text-transform: none;
--wiki-content-heading-line-height: normal;
--wiki-content-heading-text-shadow: none;
/* first heading (h1) */
--wiki-content-firstheading-border-bottom-width: var(--wiki-content-heading-border-bottom-width);
--wiki-content-firstheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-firstheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family);
--wiki-content-firstheading-font-weight: var(--wiki-content-heading-font-weight);
--wiki-content-firstheading-font-style: var(--wiki-content-heading-font-style);
--wiki-content-firstheading-text-transform: var(--wiki-content-heading-text-transform);
--wiki-content-firstheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-firstheading-color: var(--wiki-content-heading-color);
--wiki-content-firstheading-text-shadow: none;
/* sub-heading (h3, h4, h5, h6) */
--wiki-content-subheading-border-bottom-width: 0px;
--wiki-content-subheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-subheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-subheading-font-family: var(--wiki-body-font-family);
--wiki-content-subheading-font-weight: bold;
--wiki-content-subheading-font-style: normal;
--wiki-content-subheading-text-transform: none;
--wiki-content-subheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-subheading-color: var(--wiki-content-heading-color);
--wiki-content-subheading-text-shadow: none;
/* heading size */
--wiki-content-firstheading-font-size: 1.8em;
--wiki-content-heading-h2-font-size: 1.5em;
--wiki-content-heading-h3-font-size: 1.2em;
--wiki-content-heading-h4-font-size: 114%;
--wiki-content-heading-h5-font-size: 108%;
--wiki-content-heading-h6-font-size: 100%;
--wiki-content-toc-background: var(--wiki-content-background-color--secondary);
--wiki-content-toc-border-width: 1px;
--wiki-content-toc-border-style: solid;
--wiki-content-toc-border-color: var(--wiki-content-border-color);
--wiki-content-toc-border-radius: 0px;
--wiki-content-toc-border-image: none;
--wiki-content-toc-box-shadow: 0 0.1em 0.2em #000000;
--wiki-content-catlinks-background: var(--wiki-content-background-color--secondary);
--wiki-content-catlinks-border-width: 1px;
--wiki-content-catlinks-border-style: solid;
--wiki-content-catlinks-border-color: var(--wiki-content-border-color);
--wiki-content-catlinks-border-radius: 0px;
--wiki-content-catlinks-border-image: none;
--wiki-content-catlinks-box-shadow: none;
--wiki-content-filetoc-background: var(--wiki-content-background-color--secondary);
--wiki-content-filetoc-border-width: 1px;
--wiki-content-filetoc-border-style: solid;
--wiki-content-filetoc-border-color: var(--wiki-content-border-color);
--wiki-content-filetoc-border-radius: 0px;
--wiki-content-filetoc-border-image: none;
--wiki-content-filetoc-box-shadow: none;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
--wiki-sidebar-padding: 0px;
--wiki-sidebar-background-color: var(--wiki-content-background-color);
--wiki-sidebar-background-opacity: var(--wiki-content-background-opacity);
--wiki-sidebar-background-image: none;
--wiki-sidebar-background-position: center;
--wiki-sidebar-background-repeat: repeat;
--wiki-sidebar-background-size: auto;
--wiki-sidebar-filter: none;
--wiki-sidebar-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-sidebar-border-color: var(--wiki-content-border-color);
--wiki-sidebar-border-style: solid;
--wiki-sidebar-border-image: none;
--wiki-sidebar-link-color: var(--wiki-content-link-color);
--wiki-sidebar-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-sidebar-heading-color: var(--wiki-content-heading-color);
--wiki-sidebar-heading-font-weight: normal;
--wiki-sidebar-heading-font-style: normal;
--wiki-sidebar-heading-text-transform: none;
--wiki-sidebar-heading-line-height: normal;
--wiki-sidebar-heading-padding: 0.5rem 0.25rem 0.5rem 0.5rem;
--wiki-sidebar-heading-margin: 0px 0px -0.5rem 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-text-shadow: none;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-icon-to-link-filter: var(--wiki-icon-to-link-filter);
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-box-padding: 0px;
--wiki-sidebar-box-background: none;
--wiki-sidebar-box-border: 0px;
--wiki-sidebar-box-border-image: none;
--wiki-accent-color--hover: color-mix(in srgb, var(--wiki-accent-color) 90%, var(--wiki-accent-label-color));
--wiki-footer-border-width: var(--wiki-content-border-width);
--wiki-footer-border-style: var(--wiki-content-border-style);
--wiki-footer-border-color: var(--wiki-content-border-color);
--wiki-footer-background-color: var(--wiki-content-background-color);
--wiki-footer-background-opacity: var(--wiki-content-background-opacity);
--wiki-footer-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-footer-text-color: var(--wiki-content-text-color);
--wiki-footer-link-color: var(--wiki-content-link-color);
--wiki-footer-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-footer-border-radius: var(--wiki-content-border-radius);
--wiki-navigation-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-background-color--hover: var(--wiki-navigation-background-color);
--wiki-navigation-background-opacity--hover: var(--wiki-navigation-background-opacity);
--wiki-navigation-background-image--hover: var(--wiki-navigation-background-image);
--wiki-navigation-background-position--hover: var(--wiki-navigation-background-position);
--wiki-navigation-background-repeat--hover: var(--wiki-navigation-background-repeat);
--wiki-navigation-background-size--hover: var(--wiki-navigation-background-size);
--wiki-navigation-text-color--hover: var(--wiki-content-link-color--hover);
--wiki-navigation-transform--hover: none;
--wiki-navigation-selected-border-style: solid;
--wiki-navigation-selected-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-border-style: solid;
--wiki-navigation-border-color--hover: var(--wiki-navigation-border-color);
--wiki-navigation-border-image--hover: var(--wiki-navigation-border-image);
--wiki-navigation-border-bottom-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-border-bottom-style: var(--wiki-navigation-selected-border-style);
--wiki-navigation-border-bottom-width: calc(var(--wiki-is-navigation-inside-content, 0) * var(--wiki-navigation-selected-border-width, 1px) + (1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-width, 1px));
--wiki-navigation-icon-size: 1em;
--wiki-navigation-tab-padding-x--icon: var(--wiki-navigation-tab-padding-x);
--wiki-navigation-bottom-spacing: 0px; /* If you change this to greater than 0px, you should usually change the value of --wiki-navigation-selected-border-bottom-background to var(--wiki-navigation-border-bottom-color) */
--wiki-navigation-dropdown-background-color: var(--wiki-navigation-selected-background-color);
--wiki-navigation-dropdown-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-dropdown-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-dropdown-offset: 0px; /* vertical offset */
--wiki-navigation-search-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-search-background-image: none;
--wiki-navigation-search-background-position: 0;
--wiki-navigation-search-background-size: auto;
--wiki-navigation-search-background-repeat: repeat;
--wiki-navigation-search-backdrop-filter: none;
--wiki-navigation-search-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-search-border-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-border-style: solid;
--wiki-navigation-search-border-width: 1px;
--wiki-navigation-search-border-radius: 2px;
--wiki-navigation-search-border-image: none;
--wiki-navigation-search-border-image--hover: var(--wiki-navigation-search-border-image);
--wiki-navigation-search-box-shadow: none;
--wiki-navigation-search-box-shadow--hover: var(--wiki-navigation-search-box-shadow);
--wiki-navigation-search-text-color: var(--wiki-content-text-color);
--wiki-navigation-search-font-size: var(--wiki-navigation-font-size);
--wiki-navigation-search-height: 2em;
--wiki-navigation-search-button-color: currentColor;
--wiki-navigation-search-button-color--hover: var(--wiki-navigation-search-button-color);
--wiki-navigation-search-button-color-opacity: 80%;
--wiki-navigation-search-button-color-opacity--hover: 95%;
--wiki-navigation-search-bottom-spacing: 3px;
--wiki-navigation-search-highlight-background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
--wiki-navigation-gap-between-left-and-right: calc(max(0px, var(--wiki-navigation-tab-spacing))); /* minimum width between #left-navigation and #right-navigation before tabs start to collapse */
}
/*** mobile adjustments ***/
@media screen and (max-width: 720px) {
body.has-vector-mobile-menu{
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-margin: 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-margin: 0px 0px -0.5em 0px;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-background-opacity: 100%;
--wiki-navigation-search-border-width: 1px;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
}
}
/*****************************
**** END SHARED VARIABLES ****
******************************/
/******************************************************************************************
********************************* End user-edit variables *********************************
******************************************************************************************/
/******************************
* Fallback for older browsers *
* DONT EDIT THIS *
*******************************/
@supports not (color:color-mix(in srgb, #000, transparent)) {
.view-dark,
.view-light,
:root {
--wiki-content-text-mix-color: var(--wiki-content-text-color);
--wiki-content-text-mix-color-95: var(--wiki-content-background-color);
--wiki-content-background-color--secondary: var(--wiki-content-dynamic-color--secondary--inverted);
--wiki-content-border-color--secondary: var(--wiki-content-border-color);
--wiki-content-border-color--accent: var(--wiki-accent-color);
--wiki-accent-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-highlight-background-color: transparent;
}
}
/*****************************
* End older browser fallback *
******************************/
/*****************************
* PortableInfoboxes *
******************************/
:root {
--pi-background: var(--wiki-content-background-color);
--pi-secondary-background: var(--wiki-accent-color);
--pi-secondary-background-label: var(--wiki-accent-label-color);
--pi-border-color: color-mix(in srgb, var(--pi-secondary-background) 50%, transparent);
}
.portable-infobox .pi-title,
.portable-infobox .pi-header {
text-align: center;
font-size: 1.5em;
background: color-mix(in srgb, var(--pi-secondary-background) 75%, transparent);
color: var(--pi-secondary-background-label);
}
.portable-infobox .pi-data,
.portable-infobox .pi-group {
background: var(--wiki-content-background-color--secondary);
}
.portable-infobox .pi-image {
padding: 8px;
}
.pi-image-thumbnail {
max-width: 100%;
}
.pi-caption {
color: var(--wiki-content-text-mix-color);
}
.pi-section-navigation .pi-section-tab.pi-section-active,
.pi-section-navigation .pi-section-tab.current,
.pi-media-collection .pi-tab-link.current {
background: var(--pi-secondary-background);
color: var(--pi-secondary-background-label);
}
.pi-collapse > .pi-item:first-child {
cursor: pointer;
}
/* overqualify these to overwrite normal content heading styles */
.mw-body .portable-infobox h2,
.mw-body .portable-infobox h3 {
border-bottom: 0;
font-family: inherit;
font-weight: 700;
margin: 0;
}
/*****************************
* End PortableInfoboxes *
******************************/
/*******************
* Main page layout *
********************/
#mp-container {
display: grid;
gap: 10px;
}
@media screen and (max-width: 990px) {
/* for mobile screens */
#mp-container {
grid-template-areas:var(--main-page-layout--mobile);
grid-template-columns:var(--main-page-layout-columns--mobile, 100%);
}
.mp-box.mp-hide-on-mobile {
display: none;
}
}
@media screen and (min-width: 990px) and (max-width: 1350px) {
/* for narrow screens, between 990px and 1350px */
#mp-container {
grid-template-areas:var(--main-page-layout--tablet);
grid-template-columns:var(--main-page-layout-columns--tablet, 1fr 1fr);
}
.mp-box.mp-hide-on-tablet {
display: none;
}
}
@media screen and (min-width: 1350px) {
/* for all other screens, 1350px and wider */
#mp-container {
grid-template-areas:var(--main-page-layout--desktop);
grid-template-columns:var(--main-page-layout-columns--desktop, 2fr 1fr 2fr);
}
.mp-box.mp-hide-on-desktop {
display: none;
}
}
.mp-box {
position: relative;
display: flex;
flex-flow: column nowrap;
width: 100%;
box-sizing: border-box;
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 25%, transparent);
border: 1px solid var(--wiki-content-border-color);
padding: 0px;
}
.mp-body {
height: 100%;
display: flex;
padding: 0.5em;
flex-flow: column nowrap;
}
.mp-box.centered-content .mp-body {
height: 100%;
display: flex;
flex-flow: column nowrap;
justify-content: space-evenly;
}
.mp-box.has-floating-image {
display: block;
}
.mp-box.has-floating-image .mp-body {
height: unset;
display: block;
}
/* overqualified to override normal heading styles */
.mw-body .mp-box h2 {
text-align: center;
font-weight: bold;
font-family: var(--wiki-content-heading-font-family);
overflow: initial;
border-bottom: 1px solid var(--wiki-content-border-color);
font-size: 150%;
margin: 0;
padding: 5px 0;
color: var(--wiki-content-heading-color);
}
#mp-box-welcome {
text-align: center;
position: relative;
overflow: hidden;
}
#mp-box-welcome h2 {
font-size: 200%;
}
#mp-welcome {
display: flex;
flex-flow: column nowrap;
position: relative;
height: 100%;
z-index: 2;
box-sizing: border-box;
}
#mp-welcome .welcome-subtitle {
height: 100%;
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 85%, transparent);
padding: 0.5em;
}
#mp-banner {
position: absolute;
width: 100%;
height: 100%;
filter: blur(5px);
z-index: -1;
background: url(/images/e/e0/MP_banner.jpg);
background-size: cover;
background-repeat: no-repeat;
background-position: top center;
}
.view-dark #mp-banner {
filter: blur(5px) brightness(50%);
}
.view-light #mp-banner {
filter: blur(5px) contrast(50%);
}
/* [[Template:MP_link]] */
.mp-links {
--gap: 10px;
}
.mp-links > ul {
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin: 2px;
gap: var(--gap);
}
.mp-links > ul > li {
display: flex;
flex-flow: column nowrap;
align-items: stretch;
text-align: center;
box-sizing: border-box;
flex: max(calc(50% - var(--gap)), 5em) 1 1;
outline: 1px solid var(--wiki-content-link-color);
transition: 0.1s ease-in;
}
.mp-links > ul > li:hover {
background-color: color-mix(in srgb, var(--wiki-content-link-color) 20%, transparent);
}
.mp-links.columns-1 > ul > li {flex: max(calc(100% - var(--gap)), 5em) 1 1;}
.mp-links.columns-2 > ul > li {flex: max(calc(50% - var(--gap)), 5em) 1 1;}
.mp-links.columns-3 > ul > li {flex: max(calc((100% / 3) - var(--gap)), 5em) 1 1;}
.mp-links.columns-4 > ul > li {flex: max(calc(25% - var(--gap)), 5em) 1 1;}
.mp-links.columns-5 > ul > li {flex: max(calc(20% - var(--gap)), 5em) 1 1;}
.mp-links.columns-6 > ul > li {flex: max(calc((100% / 6) - var(--gap)), 5em) 1 1;}
.mp-links.columns-7 > ul > li {flex: max(calc((100% / 7) - var(--gap)), 5em) 1 1;}
.mp-links.columns-8 > ul > li {flex: max(calc((100% / 8) - var(--gap)), 5em) 1 1;}
.mp-links.columns-max > ul > li {flex: max(calc(0% - var(--gap)), 5em) 1 1;}
.mp-links > ul > li:hover a {
text-decoration: underline;
}
.mp-links > ul > li > a {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
flex: 1 1 auto;
box-sizing: border-box;
padding: 5px;
}
.mp-links > ul > li > a:first-child {
height: 100%;
}
.mp-links > ul > li > a:last-child:not(:first-child) {
height: unset;
}
.mp-links.stretch,
.mp-links.stretch > ul {
height: 100%;
}
.mp-links.side-image li {
flex-flow: row nowrap;
}
.mp-links.plain > ul > li {
outline-color: transparent;
}
/***********************
* End main page layout *
************************/
/*********************************************************************************************************************
* Semantically-correct horizontal lists (for Module:Navbox, and they're more machine-readable than {{*}}-formatting) *
**********************************************************************************************************************/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so: */
.hlist dt:not(:last-child)::after {
content: ":\20";
}
.hlist dd:not(:last-child)::after,
.hlist li:not(:last-child)::after {
/* "space, Middle Dot, space"
We use unicode numbers instead of the raw characters due to a Firefox encoding bug on unicode characters.
The space is also encoded because raw spaces combined with a unicode number strips the spaces under some conditions such as single-line lists */
/* content: "\20\00B7\20"; font-weight: bold; */
/* "space • space"
There may (and likely) be an extra whitespace between <li>s,
therefore we have to use a space character as last character of this sequence.
By this way, the last space and the next whitespce will collapse as a single space,
to make the whitespace on both sides of the middle dot the same width.
*/
content: "\20\A0\2022\A0\20";
font-weight: inherit;
}
/* Add parentheses around nested lists */
.hlist dd ol::before,
.hlist dd ul::before,
.hlist dd dl::before,
.hlist dt ol::before,
.hlist dt ul::before,
.hlist dt dl::before,
.hlist li ol::before,
.hlist li ul::before,
.hlist li dl::before {
content: "\20(";
font-weight: inherit;
}
.hlist dd ol::after,
.hlist dd ul::after,
.hlist dd dl::after,
.hlist dt ol::after,
.hlist dt ul::after,
.hlist dt dl::after,
.hlist li ol::after,
.hlist li ul::after,
.hlist li dl::after {
content: ")";
font-weight: inherit;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) ".\20";
}
/* Progressive enhancement:
* try to make the dot always follow the list item in same line
*/
.hlist :is(li,dt,dd):not(:has(:is(li,dt,dd))) {
display: inline-block;
}
/********************************************
* End semantically-correct horizontal lists *
*********************************************/
/*** Miscellaneous ***/
.responsive-image {
max-width: 100%;
height: auto;
}
.view-dark .invert-on-dark,
.view-light .invert-on-light {
filter: invert(100%);
}
.pixelated {
image-rendering: pixelated;
}
@media screen and (min-width: 720px) {
.mobileonly {
display: none;
}
}
@media screen and (max-width: 720px) {
.nomobile {
display: none;
}
}
/*** Utility classes for standard MW galleries ***/
/* it's important that spaced comes before centered in the sheet */
.gallery.gallery.gallery.spaced { /* this selector looks ridiculous but is actually part of stock Vector and therefore a necessary override */
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin-left: unset;
}
.gallery.centered {
text-align: center;
}
/**************************
* Start Modular Templates *
**************************/
/********* [[Template:Ambox]] *********/
.ambox {
--ambox-color: var(--wiki-accent-color);
border: 1px solid var(--wiki-content-border-color);
border-left: 10px solid var(--ambox-color);
border-radius: 2px;
display: flex;
align-items: center;
gap: .6em;
margin: 1em 0;
padding: 3px .6em;
background-color: var(--wiki-content-background-color--secondary);
box-shadow: 2px 2px 5px 0px #0002;
}
@media (min-width: 720px) {
.ambox {
margin-inline: 10%;
}
}
.ambox.tiny {
padding: .04rem .5em;
margin-inline: 0;
width: fit-content;
}
.ambox + .ambox {
margin-top: -.6em;
}
.ambox-content {
flex: 1;
}
.ambox-content p {
margin: .15em 0;
}
.ambox-title {
font-weight: bold;
}
/********* [[Template:Hatnote]] *********/
.hatnote {
padding: 1px 0 1px 1.6em;
margin-bottom: 0.5em;
font-style: italic;
border-top: 1px solid var(--wiki-content-border-color--secondary);
border-bottom: 1px solid var(--wiki-content-border-color--secondary);
}
.hatnote.icon {
padding-left: 0;
}
/********* [[Template:Spoiler]] *********/
.spoiler-content {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 50%, transparent);
transition: all 0.3s;
cursor: pointer;
overflow: auto;
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.spoiler-content {
background-color: var(--wiki-content-dynamic-color--secondary);
}
}
.spoiler-content > * {
pointer-events: none;
opacity: 0;
transition: all 0.3s;
}
.spoiler-content.show {
background-color: transparent;
}
.spoiler-content.show > * {
pointer-events: unset;
opacity: 1;
}
/********* [[Template:Link icon]] *********/
.link-icon {
--link-icon-line-height: 1.5em;
--link-icon-size: 1.5em;
display: inline-flex;
align-items: center;
height: var(--link-icon-line-height);
vertical-align: bottom;
}
.link-icon .regular {
align-self: center;
}
.link-icon .regular a {
display: flex;
}
.link-icon .regular img {
height: var(--link-icon-size);
max-width: var(--link-icon-size);
}
.link-icon .fallback {
outline: 1px solid var(--wiki-content-text-color);
border-radius: 50%;
text-align: center;
width: var(--link-icon-size);
line-height: var(--link-icon-size);
}
.link-icon.notext,
.link-icon.notext .fallback {
display: inline-block;
}
/********* [[Template:Quote]] *********/
.quote {
background: var(--wiki-content-background-color--secondary);
border-radius: 5px;
border: 2px solid var(--wiki-content-border-color);
margin: .5em 0;
padding: .5em;
overflow-y: hidden;
}
.quote .block {
display: block;
}
.quote .title {
font-size: large;
font-weight: bold;
}
.quote .content {
font-style: italic;
}
.quote .author {
font-weight: bold;
text-align: end;
}
.quote .marks-wrapper {
display: flex;
gap: 5px;
}
.quote .marks-wrapper::before,
.quote .marks-wrapper::after {
font-size: 100px;
line-height: 0px;
}
.quote .marks-wrapper::before {
content: "\201C";
margin-top: 40px;
}
.quote .marks-wrapper::after {
content: "\201D";
align-self: end;
margin-bottom: -10px;
}
.client-js .mw-charinsert-item {
display: none;
}
/************************
* End Modular Templates *
*************************/
/*****************************
* Used by [[Template:Color]] *
******************************/
.color__splotch {
display: inline-block;
height: 1em;
width: 1em;
box-sizing: border-box;
vertical-align: text-top;
border-radius: 50%;
border: 1px solid var(--wiki-content-text-color);
}
/*********************
* End Template:Color *
**********************/
/*********************************
* Used by [[Template:TOC limit]] *
**********************************/
.toclimit-2 .toclevel-1 ul,
.toclimit-3 .toclevel-2 ul,
.toclimit-4 .toclevel-3 ul,
.toclimit-5 .toclevel-4 ul,
.toclimit-6 .toclevel-5 ul,
.toclimit-7 .toclevel-6 ul {
display: none;
}
/*************************
* End Template:TOC limit *
**************************/
/*********************************
* Used by [[Template:TOC right]] *
**********************************/
@media all and (min-width: 720px) {
.tocright {
float: right;
clear: right;
margin: 0 0 0.5em 1em;
}
}
/*************************
* End Template:TOC right *
**************************/
8f19edf92250384883dd722759a3a6d86ee3ba9d
Meta:Manual of Style
4
845
1332
2025-08-24T20:03:40Z
Sharparam
284703
Created page with "This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki. Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia]. This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the talk page or contact wiki administrators to have it clarified. [[Category:Manual of Style]]"
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the talk page or contact wiki administrators to have it clarified.
[[Category:Manual of Style]]
0ef107d5084b9b99be53e446a3db2a66c809da2a
1335
1332
2025-08-24T20:07:30Z
Sharparam
284703
Link to talk page
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
[[Category:Manual of Style]]
e4e851f69ebaf087f36e360a8060865c9f4b2c2b
1348
1335
2025-08-24T23:25:02Z
Sharparam
284703
Add more style guides
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
== Layout ==
Overall, follow the same layout guidelines as used on Wikipedia ([[wikipedia:Wikipedia:Manual of Style/Layout|Wikipedia:Manual of Style/Layout]]).
This wiki has some common sections that do not appear on Wikipedia though, like <q>Location(s)</q>, <q>Acquisition</q>, and <q>Trivia</q>.
=== Location and acquisition ===
These are important sections and often what readers are interested in when looking up an item for example.
As such, they should appear early, but after the main body content of an article, so usually following the <q>Overview</q> section (if present).
=== Bugs ===
The bugs section is considered part of the appendices, and should appear as the first appendix item following the main content of an article.
=== Trivia ===
The trivia section is considered part of the appendices, and should appear after [[#Bugs|Bugs]].
=== Other sections ===
Sometimes it can be useful to divide an article into more unique sections, like how location articles will have sections listing items, enemies, bosses, and NPCs.
Use your best judgment for where these should be placed, as long as they come after the <q>Overview</q> section.
== Formatting ==
=== Emphasis ===
Due to how Wikitext works, using single quotes to produce italics, bold, or bolded italics (<code><nowiki>''...''</nowiki></code>, <code><nowiki>'''...'''</nowiki></code>, and <code><nowiki>'''''...'''''</nowiki></code>) results in simple typographical styles (with the HTML {{tag|i|open}} and {{tag|b|open}} tags).
When {{em|semantic}} emphasis is what is desired, use the {{tl|Em}} template to produce it (or the {{tag|em}} HTML tag, but the template should be more convenient).
For strong semantic emphasis, use the {{tl|Strong}} template which uses the {{tag|strong}} HTML tag.
== Infoboxes ==
Infoboxes are very useful to allow readers to quickly see important information in a structured manner that will be consistent between articles. They also help to apply categories to a page.
The following types of articles must have an infobox:
* NPCs ({{tl|Infobox/NPC}})
* Enemies ({{tl|Infobox/Enemy}})
* Bosses ({{tl|Infobox/Boss}})
* Items ({{tl|Infobox/Item}})
** Weapons ({{tl|Infobox/Weapon}})
** Armor ({{tl|Infobox/Armor}})
** Capes ({{tl|Infobox/Cape}})
** Shields ({{tl|Infobox/Shield}})
** Armor set ({{tl|Infobox/Armor set}})
** Amulets ({{tl|Infobox/Amulet}})
* Abilities ({{tl|Infobox/Ability}})
* Passives ({{tl|Infobox/Passive}})
There may be other infoboxes not covered in this manual, the [[:Category:Infobox templates|infobox templates category]] will list all the currently existing infobox templates.
The base {{ml|Infobox}} module should {{strong|never}} be used in an article. It is only used to create more specialized infoboxes.
(Though you can use it to spice up your user page if you want, just don't use it in mainspace content.)
When possible, the image used in the infobox should be an asset extracted from the game. When not possible, take a screenshot in the game and make sure the subject is clearly visible and isolated from unrelated objects with the background as clean as you can manage.
Keep in mind that infobox images will be sized to 300 pixels wide. (Some game assets are smaller than 300 pixels, and then there isn't much you can do, so just allow it to stretch.)
Infoboxes should be put at the top of an article, before the lead text.
== Navboxes ==
Navboxes (or navigation boxes) are put at the end of articles (before any categories) to help readers navigate between related content, like weapons.
See the [[:Category:Navigation templates|navigation templates category]] for currently existing navboxes.
Use the navbox most relevant for the type of content being edited. For example: Use the weapons navbox ({{tl|Navbox/Weapons}}) on a weapon page instead of the entire items navbox ({{tl|Navbox/Items}}), as using the latter would result in an overwhelming number of links and is less likely to be relevant to the reader.
Sometimes multiple navboxes might be relevant, with only one being the primary or most relevant. An example of this is ammunition. Longbows are very relevant and related to arrows, so it can be useful to have the longbows navbox on the page for an arrow type. [[Metal Arrows]] is an example of this. As the second navbox is secondary, it has been set to default to the collapsed state with the help of the {{para|state}} parameter on the navbox template: <syntaxhighlight lang="wikitext" inline>{{Navbox/Longbows|state=collapsed}}</syntaxhighlight>.
[[Category:Manual of Style]]
e6b0a8e76f3bd612c0987af6b3e48281d113fd51
Category:Manual of Style
14
846
1333
2025-08-24T20:04:01Z
Sharparam
284703
Created page with "Pages that deal with how the wiki should be edited."
wikitext
text/x-wiki
Pages that deal with how the wiki should be edited.
da899e150d93b28ad3a19c1041ade0e77fccf87f
Meta:MOS
4
847
1334
2025-08-24T20:04:18Z
Sharparam
284703
Redirected page to [[Meta:Manual of Style]]
wikitext
text/x-wiki
#REDIRECT [[Meta:Manual of Style]]
918040eed385668d250445cc55d1b1824e0ed37a
Template:Em
10
848
1336
2025-08-24T22:26:46Z
Sharparam
284703
Created page with "<em {{#if:{{{role|}}}|role="{{{role}}}"}} {{#if:{{{class|}}}|class="{{{class}}}"}} {{#if:{{{id|}}}|id="{{{id}}}"}} {{#if:{{{style|}}}|style="{{{style}}}"}} {{#if:{{{title|}}}|title="{{{title}}}"}}>{{{1}}}</em><noinclude> {{documentation}} <!-- Add categories to the /doc subpage, interwikis to Wikidata, not here --> </noinclude>"
wikitext
text/x-wiki
<em {{#if:{{{role|}}}|role="{{{role}}}"}} {{#if:{{{class|}}}|class="{{{class}}}"}} {{#if:{{{id|}}}|id="{{{id}}}"}} {{#if:{{{style|}}}|style="{{{style}}}"}} {{#if:{{{title|}}}|title="{{{title}}}"}}>{{{1}}}</em><noinclude>
{{documentation}}
<!-- Add categories to the /doc subpage, interwikis to Wikidata, not here -->
</noinclude>
e2fac6fb507a0dd72c4e79d02403049c7d857c8d
Template:Em/doc
10
849
1337
2025-08-24T22:28:04Z
Sharparam
284703
Created page with "{{From Wikipedia|Template:Em}} <includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
{{From Wikipedia|Template:Em}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
a4d16d9316831955f3ae49005df6a9d14e7744c4
1338
1337
2025-08-24T22:29:10Z
Sharparam
284703
Add link to strong template
wikitext
text/x-wiki
{{From Wikipedia|Template:Em}}
== See also ==
* {{tl|Strong}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
fae59b458997baf767095a83a6812fac25576f9b
Template:Strong
10
850
1339
2025-08-24T22:29:18Z
Sharparam
284703
Created page with "<strong {{#if:{{{role|}}}|role="{{{role}}}"}} {{#if:{{{class|}}}|class="{{{class}}}"}} {{#if:{{{id|}}}|id="{{{id}}}"}} {{#if:{{{style|}}}|style="{{{style}}}"}} {{#if:{{{title|}}}|title="{{{title}}}"}}>{{{1}}}</strong><noinclude> {{documentation}} <!-- Add cats and interwikis to the /doc subpage, not here! --> </noinclude>"
wikitext
text/x-wiki
<strong {{#if:{{{role|}}}|role="{{{role}}}"}} {{#if:{{{class|}}}|class="{{{class}}}"}} {{#if:{{{id|}}}|id="{{{id}}}"}} {{#if:{{{style|}}}|style="{{{style}}}"}} {{#if:{{{title|}}}|title="{{{title}}}"}}>{{{1}}}</strong><noinclude>
{{documentation}}
<!-- Add cats and interwikis to the /doc subpage, not here! -->
</noinclude>
a6c6d3b520e2018e19376e2f0e1a72801336d1df
Template:Strong/doc
10
851
1340
2025-08-24T22:30:06Z
Sharparam
284703
Created page with "{{From Wikipedia|Template:Strong}} == See also == * {{tl|Em}} <includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
{{From Wikipedia|Template:Strong}}
== See also ==
* {{tl|Em}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
8b5e840a9e0f743fb68890c95e23a65f1d450d3b
Bleak Faith: Forsaken Wiki/contribute
0
7
1341
13
2025-08-24T22:32:04Z
Sharparam
284703
Add link to manual of style
wikitext
text/x-wiki
{{Main page box/start
| title = Contribute to the wiki
}}
{{SITENAME}} is a collaborative wiki resource that is open for anyone to edit. You don't need special permission beyond [[Special:UserLogin/signup|registering]] an account to edit most pages, and your contributions can grow the wiki and help other players.
; Adding content
:* If you are unsure of what to do or how to create a page, search for a few articles on the same topic and see what they look like. You can always view the source code in a wiki and learn from what others have done.
:* An edit doesn't have to be massive; if you feel you don't want to create whole articles, then just fixing spelling errors and broken links is enough.
:* [[Special:UserLogin/signup|Register]] to edit and track your contributions.
:* Read the [[Meta:Manual of Style|Manual of Style]] for guidance on how to edit the wiki.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
fcb3d3f242ca0c4dad471938bb505c27594f44ad
Template:Tag
10
852
1342
2025-08-24T22:37:47Z
Sharparam
284703
Copied from [[wikipedia:Template:Tag]] (edit link to use Wikipedia interwiki link)
wikitext
text/x-wiki
<code class="{{#ifeq:{{{wrap|}}}|yes|wrap|nowrap}}" style="{{#ifeq:{{{style|}}}|plain|border:none;background:transparent;|{{{style|}}}}}"><!--
Opening tag
-->{{#switch:{{{2|pair}}}
|c|close =
|e|empty|s|single|v|void
|o|open
|p|pair = <{{#if:{{{link|}}}|[[wikipedia:HTML element#{{{1|tag}}}|{{{1|tag}}}]]|{{{1|tag}}}}}{{#if:{{{params|{{{attribs|}}}}}}| {{{params|{{{attribs}}}}}}}}
}}<!--
Content between tags
-->{{#switch:{{{2|pair}}}
|c|close = {{{content|}}}
|e|empty|s|single|v|void =  />
|o|open = >{{{content|}}}
|p|pair = {{#ifeq:{{{1|tag}}}|!--||>}}{{{content|...}}}
}}<!--
Closing tag
-->{{#switch:{{{2|pair}}}
|e|empty|s|single|v|void
|o|open =
|c|close
|p|pair = {{#ifeq:{{{1|tag}}}|!--|-->|</{{{1|tag}}}>}}
}}<!--
--></code><noinclude>
{{Documentation}}
</noinclude>
973b72505c3ff83d502ce65f4b01269686bdafc1
Template:Tag/doc
10
853
1343
2025-08-24T22:38:55Z
Sharparam
284703
Created page with "{{From Wikipedia|Template:Tag}} <includeonly>{{Sandbox other||[[Category:HTML typing-aid templates]][[Category:Wikitext typing-aid templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
{{From Wikipedia|Template:Tag}}
<includeonly>{{Sandbox other||[[Category:HTML typing-aid templates]][[Category:Wikitext typing-aid templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
9e7ec019dcd1a7dcedc4eef709120806464b2bee
Category:HTML typing-aid templates
14
854
1344
2025-08-24T22:39:09Z
Sharparam
284703
Created page with "[[Category:Templates]]"
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Wikitext typing-aid templates
14
855
1345
2025-08-24T22:39:21Z
Sharparam
284703
Created page with "[[Category:Templates]]"
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Template:Infobox/NPC/doc
10
344
1346
457
2025-08-24T23:11:14Z
Sharparam
284703
Fix broken image
wikitext
text/x-wiki
== Example ==
{{Infobox/NPC
| title = The Handler
| image = The Handler Blok 6147.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/NPC
| title = The Handler
| image = The Handler.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||
[[Category:Infobox templates]]
}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
11eea2529a7b33998b60fe9dc8a39e661285dbec
1347
1346
2025-08-24T23:11:28Z
Sharparam
284703
Fix outdated example
wikitext
text/x-wiki
== Example ==
{{Infobox/NPC
| title = The Handler
| image = The Handler Blok 6147.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/NPC
| title = The Handler
| image = The Handler Blok 6147.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||
[[Category:Infobox templates]]
}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
89dc6ffb6ff9ad6917d700875e0a4146d07be538
Template:DiscordLink
10
856
1349
2025-08-24T23:45:30Z
Sharparam
284703
Created page with "{{#vardefine:url|https://discord.com/invite/x7UCRbHAAq}} {{#vardefine:text|{{{text|Discord}}}}} {{#vardefine:icon|{{Yesno|{{{icon|}}}}}}} {{#switch:{{{1}}} | plain = {{#var:url}} | #default = {{#if:{{#var:icon}} | <span class="link-icon" style="--link-icon-size: 1.2em; --link-icon-line-height: 1lh;"><!-- --><span class="regular">[[File:Discord.svg|link={{#var:url}}|alt=]]</span><!-- --><span class="display-text">[{{#var:url}} {{#var:text}}]</span><!-- --><..."
wikitext
text/x-wiki
{{#vardefine:url|https://discord.com/invite/x7UCRbHAAq}}
{{#vardefine:text|{{{text|Discord}}}}}
{{#vardefine:icon|{{Yesno|{{{icon|}}}}}}}
{{#switch:{{{1}}}
| plain = {{#var:url}}
| #default = {{#if:{{#var:icon}}
| <span class="link-icon" style="--link-icon-size: 1.2em; --link-icon-line-height: 1lh;"><!--
--><span class="regular">[[File:Discord.svg|link={{#var:url}}|alt=]]</span><!--
--><span class="display-text">[{{#var:url}} {{#var:text}}]</span><!--
--></span>
| [{{#var:url}} {{#var:text}}]
}}
}}<noinclude>{{Documentation}}</noinclude>
cfefd5d3e9f55f72e09ed3338722bdc34a9c4424
1351
1349
2025-08-24T23:54:36Z
Sharparam
284703
Fix spacing and newlines
wikitext
text/x-wiki
{{#vardefine:url|https://discord.com/invite/x7UCRbHAAq}}<!--
-->{{#vardefine:text|{{{text|Discord}}}}}<!--
-->{{#vardefine:icon|{{Yesno|{{{icon|}}}}}}}<!--
-->{{#switch:{{{1}}}
| plain = {{#var:url}}
| #default = {{#if:{{#var:icon}}
| <span class="link-icon" style="--link-icon-size: 1.2em; --link-icon-line-height: 1lh;"><!--
--><span class="regular">[[File:Discord.svg|link={{#var:url}}|alt=]]</span><!--
--> <!--
--><span class="display-text">[{{#var:url}} {{#var:text}}]</span><!--
--></span>
| [{{#var:url}} {{#var:text}}]
}}
}}<noinclude>{{Documentation}}</noinclude>
c1e0c2547c9b5f013780e23c397049d7bdcc1170
Template:DiscordLink/doc
10
857
1350
2025-08-24T23:52:42Z
Sharparam
284703
Created page with "== TemplateData == <templatedata> { "params": { "1": { "label": "Type", "description": "Type of link to produce, leave unspecified or empty for default type.", "example": "plain", "type": "line", "suggestedvalues": [ "default", "plain" ], "default": "default" }, "text": { "label": "Link text", "description": "Custom text to show as the link text instead of the default \"Discord\".", "example": "BFF Discord", "type": "li..."
wikitext
text/x-wiki
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Type",
"description": "Type of link to produce, leave unspecified or empty for default type.",
"example": "plain",
"type": "line",
"suggestedvalues": [
"default",
"plain"
],
"default": "default"
},
"text": {
"label": "Link text",
"description": "Custom text to show as the link text instead of the default \"Discord\".",
"example": "BFF Discord",
"type": "line",
"default": "Discord"
},
"icon": {
"label": "Show icon",
"description": "Whether to show a Discord icon next to the link.",
"type": "boolean",
"default": "no"
}
},
"description": "Produces a link to the official Bleak Faith: Forsaken Discord server.",
"paramOrder": [
"1",
"text",
"icon"
],
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink}}</syntaxhighlight> → {{DiscordLink}}
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink|icon=yes}}</syntaxhighlight> → {{DiscordLink|icon=yes}}
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink|text=BFF Discord}}</syntaxhighlight> → {{DiscordLink|text=BFF Discord}}
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink|plain}}</syntaxhighlight> → {{DiscordLink|plain}}
<noinclude>[[Category:Template documentation]]</noinclude>
22afab3d89801781d6c6c24266696cd73a845e52
Bleak Faith: Forsaken Wiki/external
0
8
1352
387
2025-08-25T00:25:01Z
Sharparam
284703
Use [[Template:DiscordLink]] template
wikitext
text/x-wiki
{{Main page box/start
| title = External links
}}
<div class="mp-links columns-2">
* {{MP link|Official site|link=http://www.bleakfaith.com/}}
* {{MP link|Discord|link={{DiscordLink|plain}}|image=Discord.svg|size=64x64px}}
* {{MP link|Reddit|link=https://www.reddit.com/r/Bleak_Faith/|image=Reddit.svg|size=64x64px}}
* {{MP link|Steam|link=https://store.steampowered.com/app/1173220/Bleak_Faith_Forsaken/|image=Steam.svg|size=64x64px}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
8f030c58d461d7300f7d5d13f25a8a38a8a83694
Template:DiscordLink
10
856
1353
1351
2025-08-25T00:25:21Z
Sharparam
284703
Protected "[[Template:DiscordLink]]": Used on main page ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
{{#vardefine:url|https://discord.com/invite/x7UCRbHAAq}}<!--
-->{{#vardefine:text|{{{text|Discord}}}}}<!--
-->{{#vardefine:icon|{{Yesno|{{{icon|}}}}}}}<!--
-->{{#switch:{{{1}}}
| plain = {{#var:url}}
| #default = {{#if:{{#var:icon}}
| <span class="link-icon" style="--link-icon-size: 1.2em; --link-icon-line-height: 1lh;"><!--
--><span class="regular">[[File:Discord.svg|link={{#var:url}}|alt=]]</span><!--
--> <!--
--><span class="display-text">[{{#var:url}} {{#var:text}}]</span><!--
--></span>
| [{{#var:url}} {{#var:text}}]
}}
}}<noinclude>{{Documentation}}</noinclude>
c1e0c2547c9b5f013780e23c397049d7bdcc1170
Bleak Faith: Forsaken Wiki/about
0
6
1354
591
2025-08-25T00:29:50Z
Sharparam
284703
Use an actual description of the game
wikitext
text/x-wiki
{{Main page box/start
| title = About [[Bleak Faith: Forsaken]]
}}
An action role-playing game taking place inside a perpetually expanding omnistructure. An unforgiving, interconnected world you will have to explore to uncover its secrets.
<div style="text-align:right">[[Bleak Faith: Forsaken|Read more...]]</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
08505fcc3499f10ca0632566339c2eb5415d5314
Bleak Faith: Forsaken Wiki/pages
0
5
1355
593
2025-08-25T00:33:06Z
Sharparam
284703
Use more useful links
wikitext
text/x-wiki
{{Main page box/start
| title = Useful wiki pages
| class = centered-content
}}
<div class="mp-links columns-2">
* {{MP link|Items|link=Items}}
* {{MP link|Enemies|link=Enemies}}
* {{MP link|NPCs|link=NPCs}}
* {{MP link|Locations|link=Locations}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
328259a77b34d9cdc5f6ab08e48d3a850d82c4d5
Template:Infobox/Enemy
10
858
1356
2025-08-25T00:43:22Z
Sharparam
284703
Created page with "<includeonly><!-- -->{{#invoke:Infobox|main | kind = enemy | title = {{{title|{{PAGENAME}}}}} | image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}} | sections = Basic Info, Stats | Stats = HP, SharpResist, BluntResist, TechnomancyResist | SharpResist_label = [[File:Sharp outlined.png|20px|link=Sharp]] [[Sharp]] resistance | BluntResist_label = [[File:Blunt outlined.png|20px|link=Blunt]] [[Blunt]] resistance | TechnomancyResist_label = File:Technomancy outlined...."
wikitext
text/x-wiki
<includeonly><!--
-->{{#invoke:Infobox|main
| kind = enemy
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections = Basic Info, Stats
| Stats = HP, SharpResist, BluntResist, TechnomancyResist
| SharpResist_label = [[File:Sharp outlined.png|20px|link=Sharp]] [[Sharp]] resistance
| BluntResist_label = [[File:Blunt outlined.png|20px|link=Blunt]] [[Blunt]] resistance
| TechnomancyResist_label = [[File:Technomancy outlined.png|20px|link=Technomancy]] [[Technomancy]] resistance
| SharpResist = {{#if:{{{SharpResist|}}}|{{{SharpResist}}}%}}
| BluntResist = {{#if:{{{BluntResist|}}}|{{{BluntResist}}}%}}
| TechnomancyResist = {{#if:{{{TechnomancyResist|}}}|{{{TechnomancyResist}}}%}}
}}{{Main other|[[Category:Enemies]]}}<!--
--></includeonly><noinclude>{{Documentation}}</noinclude>
1bd8491f251c3c6a83473071b7eacf3917f0e4de
Template:Infobox/Enemy/doc
10
859
1357
2025-08-25T00:43:54Z
Sharparam
284703
Created page with "<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
d9c0501a4a136d46ea3e3e622e8875aba5810496
1362
1357
2025-08-25T08:21:23Z
Sharparam
284703
Add an example
wikitext
text/x-wiki
== Examples ==
{{Infobox/Enemy
| title = Spooky Scary Skeleton
| image = Skeleton.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Enemy
| title = Spooky Scary Skeleton
| image = Skeleton.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
35bb55d7b13bc4302d35488bfbaec23d8efc421c
Fisherman
0
541
1358
843
2025-08-25T00:46:32Z
Sharparam
284703
Sharparam renamed page [[Diver]] to [[Fisherman]]: Game files call the enemy "Fisherman"
wikitext
text/x-wiki
The '''{{PAGENAME}}''' is an enemy in {{BFF}} that appears in the [[Deluge]] location.
== Drops ==
* [[Diver's Lungs Concoction]]
* [[Fractal Fungus]]
* [[Gingko Leaves]]
* [[Lesser Anomalous Crystal]]
* [[Lesser Restorative Fluid]]
* [[Ring of Burning Desire]]
* [[Sludge]]
* [[Upgrade Splinter]]
[[Category:Enemies]]
854a2903c300d816cf3a65b85c7bee9c7c9aeb6e
1360
1358
2025-08-25T00:47:22Z
Sharparam
284703
Add infobox and navbox
wikitext
text/x-wiki
{{Infobox/Enemy
| image = Fisherman.png
}}
The '''{{PAGENAME}}''' is an enemy in {{BFF}} that appears in the [[Deluge]] location.
== Drops ==
* [[Diver's Lungs Concoction]]
* [[Fractal Fungus]]
* [[Gingko Leaves]]
* [[Lesser Anomalous Crystal]]
* [[Lesser Restorative Fluid]]
* [[Ring of Burning Desire]]
* [[Sludge]]
* [[Upgrade Splinter]]
{{Navbox/Enemies}}
[[Category:Enemies]]
67a919be1ad3071e55951b7b9ca8a26908ed2b7b
Diver
0
860
1359
2025-08-25T00:46:32Z
Sharparam
284703
Sharparam renamed page [[Diver]] to [[Fisherman]]: Game files call the enemy "Fisherman"
wikitext
text/x-wiki
#REDIRECT [[Fisherman]]
1642569f235baad045394007c41efb6519d7b76e
Anomaly (location)
0
363
1361
489
2025-08-25T01:26:38Z
Sharparam
284703
Add NPCs and bosses
wikitext
text/x-wiki
[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]]
The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]]
{{Navbox/Locations}}
[[Category:Locations]]
8859acb4f72b39a0babab381a5fceb3b14b74005
Template:Infobox/Boss/doc
10
861
1363
2025-08-25T08:22:42Z
Sharparam
284703
Created page with "== Examples == {{Infobox/Boss | title = Big Boss | image = Big Boss.png }} <syntaxhighlight lang="wikitext"> {{Infobox/Boss | title = Big Boss | image = Big Boss.png }} </syntaxhighlight> <includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== Examples ==
{{Infobox/Boss
| title = Big Boss
| image = Big Boss.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Boss
| title = Big Boss
| image = Big Boss.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
6c59a5db79b0bb269e62a3ae86ee8d15b23aab40
Template:Infobox/Boss
10
461
1364
687
2025-08-25T08:23:32Z
Sharparam
284703
Use [[Template:Main other]] and remove redundant category (specified in doc subpage)
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
| kind = boss
| sep=,
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| title = {{{title|{{PAGENAME}}}}}
| sections = Basic Info, Stats
| Stats = HP, SharpResist, BluntResist, TechnomancyResist
| SharpResist_label = [[File:Sharp outlined.png|20px|link=Sharp]] [[Sharp]] resistance
| BluntResist_label = [[File:Blunt outlined.png|20px|link=Blunt]] [[Blunt]] resistance
| TechnomancyResist_label = [[File:Technomancy outlined.png|20px|link=Technomancy]] [[Technomancy]] resistance
| SharpResist = {{#if:{{{SharpResist|}}}|{{{SharpResist}}}%}}
| BluntResist = {{#if:{{{BluntResist|}}}|{{{BluntResist}}}%}}
| TechnomancyResist = {{#if:{{{TechnomancyResist|}}}|{{{TechnomancyResist}}}%}}
}}{{Main other|[[Category:Bosses]]}}</includeonly><noinclude>
{{Documentation}}
</noinclude>
650d981203e72993b0187187d664318bb19f9d7a
File:Site-background.jpg
6
862
1365
2025-08-25T16:29:08Z
Sharparam
284703
From the screenshots page of SteamDB: https://steamdb.info/app/1173220/screenshots/
wikitext
text/x-wiki
== Summary ==
From the screenshots page of SteamDB: https://steamdb.info/app/1173220/screenshots/
== Licensing ==
{{License|game}}
391d84247204e37d49101e889156741a84adf2d1
1369
1365
2025-08-25T16:44:00Z
Sharparam
284703
Protected "[[File:Site-background.jpg]]": Part of skin ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite) [Upload=Allow only administrators] (indefinite))
wikitext
text/x-wiki
== Summary ==
From the screenshots page of SteamDB: https://steamdb.info/app/1173220/screenshots/
== Licensing ==
{{License|game}}
391d84247204e37d49101e889156741a84adf2d1
MediaWiki:Common.css
8
235
1366
1331
2025-08-25T16:34:45Z
Sharparam
284703
Set background for dark theme
css
text/css
/* CSS placed here will be applied to all skins */
/******************************************************************************************
********************************* Start user-edit variables *******************************
******************************************************************************************/
/*****************************************
****** START BASIC DESIGN VARIABLES ******
----------------------------------------*/
:root {
--wiki-content-heading-font-family: 'Linux Libertine', 'Georgia', 'Times', serif;
--wiki-sidebar-heading-font-family: sans-serif;
--wiki-content-border-radius: 0px;
--wiki-sidebar-border-radius: 0px;
}
/*----------------------------------------
******* END BASIC DESIGN VARIABLES *******
*****************************************/
/*****************************************
****** START BASIC COLOR VARIABLES *******
----------------------------------------*/
:root,
/* Begin light styles, delete from here to "end light styles" if you don't want your wiki to support any light themes (remove from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=light, */
/* individual themes are prefixed with .theme- instead */
.view-light {
/**********************
* Probably edit these * [ LIGHT VIEW ]
***********************/
--wiki-body-background-color: #F6F6F6;
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-content-background-color: #ffffff;
--wiki-content-background-opacity: 100%;
--wiki-content-border-color: #a7d7f9;
--wiki-content-link-color: #0645ad; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ LIGHT VIEW ] */
--wiki-accent-color: #3366cc;
--wiki-accent-label-color: #ffffff;
--wiki-accent-link-color: #D5FB51;
--wiki-icon-to-link-filter: invert(20%) sepia(93%) saturate(2141%) hue-rotate(210deg) brightness(83%) contrast(103%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
}
/* end light styles */
/* Begin dark styles, delete from here to "end dark styles" if you don't want your wiki to support any dark themes (remove it from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=dark, */
/* individual themes are prefixed with .theme- instead */
.view-dark {
/**********************
* Probably edit these * [ DARK VIEW ]
***********************/
--wiki-body-background-color: #171717;
--wiki-body-background-image: url(filepath://Site-background-dark.jpg);
--wiki-content-background-color: #202020;
--wiki-content-background-opacity: 90%;
/* DEFAULT: --wiki-content-border-color: #991A51; */
--wiki-content-border-color: hsl(0deg 0% 30%);
--wiki-content-link-color: #6d8afb; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ DARK VIEW ] */
/* DEFAULT: --wiki-accent-color: #ff4d9d; */
--wiki-accent-color: hsl(0deg 0% 75%);
--wiki-accent-label-color: #000;
--wiki-accent-link-color: #1e1e43;
--wiki-icon-to-link-filter: invert(60%) sepia(70%) saturate(3715%) hue-rotate(206deg) brightness(101%) contrast(97%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
/* Site background */
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-body-background-position: center;
--wiki-body-background-size: cover;
--wiki-body-background-attachment: fixed;
}
/* End dark styles */
/*----------------------------------------
******* END BASIC COLOR VARIABLES ********
*****************************************/
/*****************************************
**** START ADVANCED COLOR VARIABLES ******
----------------------------------------*/
:root,
.view-light {
/*******************
* Maybe edit these * [ LIGHT VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #111111;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #ba0000;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ LIGHT VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ LIGHT VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #bf0017;
--wiki-warning-color: #b05f30;
--wiki-success-color: #0c742f;
/**/
/***********************************
* Likely do not need to edit these * [ LIGHT VIEW ]
************************************/
--wiki-body-dynamic-color: #000000;
--wiki-body-dynamic-color--inverted: #ffffff;
--wiki-body-dynamic-color--secondary: #333333;
--wiki-body-dynamic-color--secondary--inverted: #cccccc;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #ffffff;
--wiki-content-dynamic-color: #000000;
--wiki-content-dynamic-color--inverted: #ffffff;
--wiki-content-dynamic-color--secondary: #333333;
--wiki-content-dynamic-color--secondary--inverted: #cccccc;
/* [ LIGHT VIEW ] */
--wiki-alert-label-color: #ffffff;
--wiki-warning-label-color: #ffffff;
--wiki-success-label-color: #ffffff;
--wiki-icon-general-filter: ; /* do not set this to none, ignore the "unexpected token" error */
/**/
}
.view-dark {
/*******************
* Maybe edit these * [ DARK VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #ededed;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #FC5B4F;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ DARK VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ DARK VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #ff576a;
--wiki-warning-color: #cf721c;
--wiki-success-color: #13aa45;
/**/
/***********************************
* Likely do not need to edit these * [ DARK VIEW ]
************************************/
--wiki-body-dynamic-color: #ffffff;
--wiki-body-dynamic-color--inverted: #000000;
--wiki-body-dynamic-color--secondary: #cccccc;
--wiki-body-dynamic-color--secondary--inverted: #333333;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #000;
--wiki-content-dynamic-color: #ffffff;
--wiki-content-dynamic-color--inverted: #000000;
--wiki-content-dynamic-color--secondary: #cccccc;
--wiki-content-dynamic-color--secondary--inverted: #333333;
/* [ DARK VIEW ] */
--wiki-alert-label-color: #000000;
--wiki-warning-label-color: #000000;
--wiki-success-label-color: #000000;
--wiki-icon-general-filter: invert(100%);
}
/*----------------------------------------
***** END ADVANCED COLOR VARIABLES *******
*****************************************/
/*****************************************
**** START ADVANCED DESIGN VARIABLES *****
----------------------------------------*/
:root {
/***********************
start logo position
----------------------*/
--wiki-is-top-logo: 0; /* 1 = center logo at the top of the page; 0 = logo at the top left of the page */
--wiki-logo-file-width: 160; /* Width of the image file in px. Put a number without the letters `px`. */
--wiki-logo-file-height: 160; /* Height of the image file in px. Put a number without the letters `px`. */
--wiki-logo-height: calc(var(--wiki-logo-file-height)*1px); /* Valid only when --wiki-is-top-logo is 1. The height the logo should be shown */
--wiki-logo-margin: 15px; /* the width of margin below the logo. When --wiki-is-top-logo is 1, this is also the default value of --wiki-top-spacing */
/*-----------------------
end logo position
***********************/
--wiki-is-navigation-inside-content: 0; /* 0 = default navigation tabs layout; 1 = navigation tabs inside content box */
--wiki-body-font-family: sans-serif;
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family); /* only apply to the main title of article */
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-width: 1px;
--wiki-sidebar-width: 10em; /* width of sidebar(#mw-panel) */
--wiki-sidebar-portal-spacing: 0px;
--wiki-sidebar-border-width: var(--wiki-content-border-width);
--wiki-navigation-border-radius: 0px; /* border radius of tabs */
/*******************
* Maybe edit these * [ DESIGN ]
********************/
--wiki-logo-filter: none;
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-top-radius: var(--wiki-content-border-radius);
--wiki-content-border-style: solid;
--wiki-content-border-image: none;
--wiki-content-backdrop-filter: none;
--wiki-page-content-max-width: 9999px; /* max width of sidebar+gap+content, must be a length value. A huge value can be used to indicate no limit, e.g. 99999px */
--wiki-gap-between-sidebar-and-content: 0.5em; /* gap between sidebar(#mw-panel) and content(#content) */
--wiki-sidebar-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-heading-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-margin: 0.5em;
--wiki-sidebar-list-item-padding: 0.25em 0.25rem;
--wiki-sidebar-list-padding: 0.25rem;
--wiki-sidebar-list-item-background--hover: none; /* background of hover item */
--wiki-navigation-font-size: 0.8125em; /* please use em or rem for this */
--wiki-navigation-height: 2.75rem; /* height of navigation area,include spacing above tabs */
--wiki-navigation-left-spacing: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-radius) + var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-right-spacing: calc( var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-box-background-color: var(--wiki-content-background-color);
--wiki-navigation-box-background-opacity: calc(var(--wiki-content-background-opacity)*0.8*var(--wiki-is-navigation-inside-content));
--wiki-navigation-box-background: color-mix(in srgb, var(--wiki-navigation-box-background-color) var(--wiki-navigation-box-background-opacity), transparent); /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-border-image: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-backdrop-filter: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-selected-backdrop-filter: var(--wiki-content-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
--wiki-navigation-backdrop-filter: var(--wiki-navigation-selected-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
/* nav tabs style. The vector gradient is default.
* If you want to customize the style of tabs, it's easier to start with the following settings:
* --wiki-navigation-background-image: none;
* --wiki-navigation-selected-background-image: none;
* --wiki-navigation-selected-border-width: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-width) + var(--wiki-is-navigation-inside-content) * 1px );
* --wiki-navigation-selected-border-bottom-background: none;
* --wiki-navigation-tab-spacing: 0.25em;
* --wiki-navigation-tab-padding-top: 0.5em;
* --wiki-navigation-tab-padding-bottom: 0.5em;
*/
--wiki-navigation-tab-spacing: -1px; /* width of the space between tabs, can be a negative number, in which case adjacent tabs will overlap */
--wiki-navigation-tab-padding-top: 1.25em;
--wiki-navigation-tab-padding-x: 0.75em;
--wiki-navigation-tab-padding-bottom: 4px;
--wiki-navigation-selected-border-width: 0px; /* border width of selected tabs */
--wiki-navigation-border-width: var(--wiki-navigation-selected-border-width); /* border width of normal tabs */
--wiki-navigation-border-image: none;
--wiki-navigation-selected-border-image: var(--wiki-navigation-border-image);
--wiki-navigation-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to top,var(--wiki-navigation-background-color) 0,var(--wiki-navigation-selected-background-color) 100%);
--wiki-navigation-background-repeat: no-repeat, no-repeat, repeat-x;
--wiki-navigation-background-position: left bottom, right bottom, left bottom;
--wiki-navigation-background-size: 1px 100%, 1px 100%, 100%;
--wiki-navigation-selected-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%);
--wiki-navigation-selected-background-repeat: no-repeat, no-repeat;
--wiki-navigation-selected-background-position: left bottom, right bottom;
--wiki-navigation-selected-background-size: 1px 100%, 1px 100%;
--wiki-navigation-selected-border-bottom-background: linear-gradient(to right, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px), linear-gradient(to left, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px);
/* affects the dropdown menu under More */
--wiki-navigation-dropdown-text-color: var(--wiki-navigation-text-color);
--wiki-navigation-dropdown-text-color--hover: var(--wiki-navigation-dropdown-text-color);
--wiki-navigation-dropdown-font-size: var(--wiki-navigation-font-size); /* please use em or rem for this */
--wiki-navigation-dropdown-border-width: 1px;
--wiki-navigation-dropdown-border-radius: var(--wiki-navigation-border-radius);
--wiki-navigation-dropdown-padding: 0.25em; /* padding of the dropdown menu box */
--wiki-navigation-dropdown-item-padding: 0.625em; /* padding of each dropdown menu items */
--wiki-navigation-dropdown-item-background--hover: none; /* background of hover item */
--wiki-navigation-dropdown-border-image: none;
--wiki-navigation-dropdown-backdrop-filter: none;
--wiki-navigation-dropdown-box-shadow: none; /* box shadow */
/* styles of the footer */
--wiki-spacing-before-footer: 0px;
--wiki-footer-border-image: none;
/* padding on body element */
--wiki-top-spacing: calc(var(--wiki-is-top-logo)*var(--wiki-logo-margin) + (1 - var(--wiki-is-top-logo))*1em); /* extra spacing below wiki.gg netbar */
--wiki-left-spacing: 0.5em;
--wiki-right-spacing: 1em;
--wiki-bottom-spacing: 2em;
/* end design variables */
}
/*----------------------------------------
***** END ADVANCED DESIGN VARIABLES ******
*****************************************/
/*******************************
**** START SHARED VARIABLES ****
**** tl;dr: don't edit this ****
********************************/
/*
These variables are rarely touched, usually inherit other variables, and are shared on all themes.
In 99% of cases none of these are ever edited, and you should only be doing so if you have a very clear vision,
understand what you are doing, and *know* that what you are trying to do is not accomplished by changing
another variable in the above sections.
Since these are by default shared across all themes, if you support multiple themes you'll probably want to
separate the variables you want to modify here into .view-x blocks like above. If you don't understand
what that means or how to do that then you probably shouldn't be modifying this section.
*/
:root {
--wiki-content-border-bottom-width: var(--wiki-content-border-width);
--wiki-content-border-bottom-style: var(--wiki-content-border-style);
--wiki-content-border-bottom-color: var(--wiki-content-border-color);
--wiki-content-text-mix-color: color-mix(in srgb, var(--wiki-content-background-color), var(--wiki-content-text-color) 62%);
--wiki-content-text-mix-color-95: color-mix(in srgb, var(--wiki-content-background-color) 95%, var(--wiki-content-text-color));
--wiki-content-text-color--hover: var(--wiki-content-text-color);
/* heading */
--wiki-content-heading-border-bottom-width: 1px;
--wiki-content-heading-border-style: solid;
--wiki-content-heading-font-weight: normal;
--wiki-content-heading-font-style: normal;
--wiki-content-heading-text-transform: none;
--wiki-content-heading-line-height: normal;
--wiki-content-heading-text-shadow: none;
/* first heading (h1) */
--wiki-content-firstheading-border-bottom-width: var(--wiki-content-heading-border-bottom-width);
--wiki-content-firstheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-firstheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family);
--wiki-content-firstheading-font-weight: var(--wiki-content-heading-font-weight);
--wiki-content-firstheading-font-style: var(--wiki-content-heading-font-style);
--wiki-content-firstheading-text-transform: var(--wiki-content-heading-text-transform);
--wiki-content-firstheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-firstheading-color: var(--wiki-content-heading-color);
--wiki-content-firstheading-text-shadow: none;
/* sub-heading (h3, h4, h5, h6) */
--wiki-content-subheading-border-bottom-width: 0px;
--wiki-content-subheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-subheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-subheading-font-family: var(--wiki-body-font-family);
--wiki-content-subheading-font-weight: bold;
--wiki-content-subheading-font-style: normal;
--wiki-content-subheading-text-transform: none;
--wiki-content-subheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-subheading-color: var(--wiki-content-heading-color);
--wiki-content-subheading-text-shadow: none;
/* heading size */
--wiki-content-firstheading-font-size: 1.8em;
--wiki-content-heading-h2-font-size: 1.5em;
--wiki-content-heading-h3-font-size: 1.2em;
--wiki-content-heading-h4-font-size: 114%;
--wiki-content-heading-h5-font-size: 108%;
--wiki-content-heading-h6-font-size: 100%;
--wiki-content-toc-background: var(--wiki-content-background-color--secondary);
--wiki-content-toc-border-width: 1px;
--wiki-content-toc-border-style: solid;
--wiki-content-toc-border-color: var(--wiki-content-border-color);
--wiki-content-toc-border-radius: 0px;
--wiki-content-toc-border-image: none;
--wiki-content-toc-box-shadow: 0 0.1em 0.2em #000000;
--wiki-content-catlinks-background: var(--wiki-content-background-color--secondary);
--wiki-content-catlinks-border-width: 1px;
--wiki-content-catlinks-border-style: solid;
--wiki-content-catlinks-border-color: var(--wiki-content-border-color);
--wiki-content-catlinks-border-radius: 0px;
--wiki-content-catlinks-border-image: none;
--wiki-content-catlinks-box-shadow: none;
--wiki-content-filetoc-background: var(--wiki-content-background-color--secondary);
--wiki-content-filetoc-border-width: 1px;
--wiki-content-filetoc-border-style: solid;
--wiki-content-filetoc-border-color: var(--wiki-content-border-color);
--wiki-content-filetoc-border-radius: 0px;
--wiki-content-filetoc-border-image: none;
--wiki-content-filetoc-box-shadow: none;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
--wiki-sidebar-padding: 0px;
--wiki-sidebar-background-color: var(--wiki-content-background-color);
--wiki-sidebar-background-opacity: var(--wiki-content-background-opacity);
--wiki-sidebar-background-image: none;
--wiki-sidebar-background-position: center;
--wiki-sidebar-background-repeat: repeat;
--wiki-sidebar-background-size: auto;
--wiki-sidebar-filter: none;
--wiki-sidebar-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-sidebar-border-color: var(--wiki-content-border-color);
--wiki-sidebar-border-style: solid;
--wiki-sidebar-border-image: none;
--wiki-sidebar-link-color: var(--wiki-content-link-color);
--wiki-sidebar-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-sidebar-heading-color: var(--wiki-content-heading-color);
--wiki-sidebar-heading-font-weight: normal;
--wiki-sidebar-heading-font-style: normal;
--wiki-sidebar-heading-text-transform: none;
--wiki-sidebar-heading-line-height: normal;
--wiki-sidebar-heading-padding: 0.5rem 0.25rem 0.5rem 0.5rem;
--wiki-sidebar-heading-margin: 0px 0px -0.5rem 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-text-shadow: none;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-icon-to-link-filter: var(--wiki-icon-to-link-filter);
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-box-padding: 0px;
--wiki-sidebar-box-background: none;
--wiki-sidebar-box-border: 0px;
--wiki-sidebar-box-border-image: none;
--wiki-accent-color--hover: color-mix(in srgb, var(--wiki-accent-color) 90%, var(--wiki-accent-label-color));
--wiki-footer-border-width: var(--wiki-content-border-width);
--wiki-footer-border-style: var(--wiki-content-border-style);
--wiki-footer-border-color: var(--wiki-content-border-color);
--wiki-footer-background-color: var(--wiki-content-background-color);
--wiki-footer-background-opacity: var(--wiki-content-background-opacity);
--wiki-footer-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-footer-text-color: var(--wiki-content-text-color);
--wiki-footer-link-color: var(--wiki-content-link-color);
--wiki-footer-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-footer-border-radius: var(--wiki-content-border-radius);
--wiki-navigation-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-background-color--hover: var(--wiki-navigation-background-color);
--wiki-navigation-background-opacity--hover: var(--wiki-navigation-background-opacity);
--wiki-navigation-background-image--hover: var(--wiki-navigation-background-image);
--wiki-navigation-background-position--hover: var(--wiki-navigation-background-position);
--wiki-navigation-background-repeat--hover: var(--wiki-navigation-background-repeat);
--wiki-navigation-background-size--hover: var(--wiki-navigation-background-size);
--wiki-navigation-text-color--hover: var(--wiki-content-link-color--hover);
--wiki-navigation-transform--hover: none;
--wiki-navigation-selected-border-style: solid;
--wiki-navigation-selected-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-border-style: solid;
--wiki-navigation-border-color--hover: var(--wiki-navigation-border-color);
--wiki-navigation-border-image--hover: var(--wiki-navigation-border-image);
--wiki-navigation-border-bottom-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-border-bottom-style: var(--wiki-navigation-selected-border-style);
--wiki-navigation-border-bottom-width: calc(var(--wiki-is-navigation-inside-content, 0) * var(--wiki-navigation-selected-border-width, 1px) + (1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-width, 1px));
--wiki-navigation-icon-size: 1em;
--wiki-navigation-tab-padding-x--icon: var(--wiki-navigation-tab-padding-x);
--wiki-navigation-bottom-spacing: 0px; /* If you change this to greater than 0px, you should usually change the value of --wiki-navigation-selected-border-bottom-background to var(--wiki-navigation-border-bottom-color) */
--wiki-navigation-dropdown-background-color: var(--wiki-navigation-selected-background-color);
--wiki-navigation-dropdown-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-dropdown-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-dropdown-offset: 0px; /* vertical offset */
--wiki-navigation-search-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-search-background-image: none;
--wiki-navigation-search-background-position: 0;
--wiki-navigation-search-background-size: auto;
--wiki-navigation-search-background-repeat: repeat;
--wiki-navigation-search-backdrop-filter: none;
--wiki-navigation-search-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-search-border-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-border-style: solid;
--wiki-navigation-search-border-width: 1px;
--wiki-navigation-search-border-radius: 2px;
--wiki-navigation-search-border-image: none;
--wiki-navigation-search-border-image--hover: var(--wiki-navigation-search-border-image);
--wiki-navigation-search-box-shadow: none;
--wiki-navigation-search-box-shadow--hover: var(--wiki-navigation-search-box-shadow);
--wiki-navigation-search-text-color: var(--wiki-content-text-color);
--wiki-navigation-search-font-size: var(--wiki-navigation-font-size);
--wiki-navigation-search-height: 2em;
--wiki-navigation-search-button-color: currentColor;
--wiki-navigation-search-button-color--hover: var(--wiki-navigation-search-button-color);
--wiki-navigation-search-button-color-opacity: 80%;
--wiki-navigation-search-button-color-opacity--hover: 95%;
--wiki-navigation-search-bottom-spacing: 3px;
--wiki-navigation-search-highlight-background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
--wiki-navigation-gap-between-left-and-right: calc(max(0px, var(--wiki-navigation-tab-spacing))); /* minimum width between #left-navigation and #right-navigation before tabs start to collapse */
}
/*** mobile adjustments ***/
@media screen and (max-width: 720px) {
body.has-vector-mobile-menu{
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-margin: 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-margin: 0px 0px -0.5em 0px;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-background-opacity: 100%;
--wiki-navigation-search-border-width: 1px;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
}
}
/*****************************
**** END SHARED VARIABLES ****
******************************/
/******************************************************************************************
********************************* End user-edit variables *********************************
******************************************************************************************/
/******************************
* Fallback for older browsers *
* DONT EDIT THIS *
*******************************/
@supports not (color:color-mix(in srgb, #000, transparent)) {
.view-dark,
.view-light,
:root {
--wiki-content-text-mix-color: var(--wiki-content-text-color);
--wiki-content-text-mix-color-95: var(--wiki-content-background-color);
--wiki-content-background-color--secondary: var(--wiki-content-dynamic-color--secondary--inverted);
--wiki-content-border-color--secondary: var(--wiki-content-border-color);
--wiki-content-border-color--accent: var(--wiki-accent-color);
--wiki-accent-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-highlight-background-color: transparent;
}
}
/*****************************
* End older browser fallback *
******************************/
/*****************************
* PortableInfoboxes *
******************************/
:root {
--pi-background: var(--wiki-content-background-color);
--pi-secondary-background: var(--wiki-accent-color);
--pi-secondary-background-label: var(--wiki-accent-label-color);
--pi-border-color: color-mix(in srgb, var(--pi-secondary-background) 50%, transparent);
}
.portable-infobox .pi-title,
.portable-infobox .pi-header {
text-align: center;
font-size: 1.5em;
background: color-mix(in srgb, var(--pi-secondary-background) 75%, transparent);
color: var(--pi-secondary-background-label);
}
.portable-infobox .pi-data,
.portable-infobox .pi-group {
background: var(--wiki-content-background-color--secondary);
}
.portable-infobox .pi-image {
padding: 8px;
}
.pi-image-thumbnail {
max-width: 100%;
}
.pi-caption {
color: var(--wiki-content-text-mix-color);
}
.pi-section-navigation .pi-section-tab.pi-section-active,
.pi-section-navigation .pi-section-tab.current,
.pi-media-collection .pi-tab-link.current {
background: var(--pi-secondary-background);
color: var(--pi-secondary-background-label);
}
.pi-collapse > .pi-item:first-child {
cursor: pointer;
}
/* overqualify these to overwrite normal content heading styles */
.mw-body .portable-infobox h2,
.mw-body .portable-infobox h3 {
border-bottom: 0;
font-family: inherit;
font-weight: 700;
margin: 0;
}
/*****************************
* End PortableInfoboxes *
******************************/
/*******************
* Main page layout *
********************/
#mp-container {
display: grid;
gap: 10px;
}
@media screen and (max-width: 990px) {
/* for mobile screens */
#mp-container {
grid-template-areas:var(--main-page-layout--mobile);
grid-template-columns:var(--main-page-layout-columns--mobile, 100%);
}
.mp-box.mp-hide-on-mobile {
display: none;
}
}
@media screen and (min-width: 990px) and (max-width: 1350px) {
/* for narrow screens, between 990px and 1350px */
#mp-container {
grid-template-areas:var(--main-page-layout--tablet);
grid-template-columns:var(--main-page-layout-columns--tablet, 1fr 1fr);
}
.mp-box.mp-hide-on-tablet {
display: none;
}
}
@media screen and (min-width: 1350px) {
/* for all other screens, 1350px and wider */
#mp-container {
grid-template-areas:var(--main-page-layout--desktop);
grid-template-columns:var(--main-page-layout-columns--desktop, 2fr 1fr 2fr);
}
.mp-box.mp-hide-on-desktop {
display: none;
}
}
.mp-box {
position: relative;
display: flex;
flex-flow: column nowrap;
width: 100%;
box-sizing: border-box;
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 25%, transparent);
border: 1px solid var(--wiki-content-border-color);
padding: 0px;
}
.mp-body {
height: 100%;
display: flex;
padding: 0.5em;
flex-flow: column nowrap;
}
.mp-box.centered-content .mp-body {
height: 100%;
display: flex;
flex-flow: column nowrap;
justify-content: space-evenly;
}
.mp-box.has-floating-image {
display: block;
}
.mp-box.has-floating-image .mp-body {
height: unset;
display: block;
}
/* overqualified to override normal heading styles */
.mw-body .mp-box h2 {
text-align: center;
font-weight: bold;
font-family: var(--wiki-content-heading-font-family);
overflow: initial;
border-bottom: 1px solid var(--wiki-content-border-color);
font-size: 150%;
margin: 0;
padding: 5px 0;
color: var(--wiki-content-heading-color);
}
#mp-box-welcome {
text-align: center;
position: relative;
overflow: hidden;
}
#mp-box-welcome h2 {
font-size: 200%;
}
#mp-welcome {
display: flex;
flex-flow: column nowrap;
position: relative;
height: 100%;
z-index: 2;
box-sizing: border-box;
}
#mp-welcome .welcome-subtitle {
height: 100%;
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 85%, transparent);
padding: 0.5em;
}
#mp-banner {
position: absolute;
width: 100%;
height: 100%;
filter: blur(5px);
z-index: -1;
background: url(/images/e/e0/MP_banner.jpg);
background-size: cover;
background-repeat: no-repeat;
background-position: top center;
}
.view-dark #mp-banner {
filter: blur(5px) brightness(50%);
}
.view-light #mp-banner {
filter: blur(5px) contrast(50%);
}
/* [[Template:MP_link]] */
.mp-links {
--gap: 10px;
}
.mp-links > ul {
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin: 2px;
gap: var(--gap);
}
.mp-links > ul > li {
display: flex;
flex-flow: column nowrap;
align-items: stretch;
text-align: center;
box-sizing: border-box;
flex: max(calc(50% - var(--gap)), 5em) 1 1;
outline: 1px solid var(--wiki-content-link-color);
transition: 0.1s ease-in;
}
.mp-links > ul > li:hover {
background-color: color-mix(in srgb, var(--wiki-content-link-color) 20%, transparent);
}
.mp-links.columns-1 > ul > li {flex: max(calc(100% - var(--gap)), 5em) 1 1;}
.mp-links.columns-2 > ul > li {flex: max(calc(50% - var(--gap)), 5em) 1 1;}
.mp-links.columns-3 > ul > li {flex: max(calc((100% / 3) - var(--gap)), 5em) 1 1;}
.mp-links.columns-4 > ul > li {flex: max(calc(25% - var(--gap)), 5em) 1 1;}
.mp-links.columns-5 > ul > li {flex: max(calc(20% - var(--gap)), 5em) 1 1;}
.mp-links.columns-6 > ul > li {flex: max(calc((100% / 6) - var(--gap)), 5em) 1 1;}
.mp-links.columns-7 > ul > li {flex: max(calc((100% / 7) - var(--gap)), 5em) 1 1;}
.mp-links.columns-8 > ul > li {flex: max(calc((100% / 8) - var(--gap)), 5em) 1 1;}
.mp-links.columns-max > ul > li {flex: max(calc(0% - var(--gap)), 5em) 1 1;}
.mp-links > ul > li:hover a {
text-decoration: underline;
}
.mp-links > ul > li > a {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
flex: 1 1 auto;
box-sizing: border-box;
padding: 5px;
}
.mp-links > ul > li > a:first-child {
height: 100%;
}
.mp-links > ul > li > a:last-child:not(:first-child) {
height: unset;
}
.mp-links.stretch,
.mp-links.stretch > ul {
height: 100%;
}
.mp-links.side-image li {
flex-flow: row nowrap;
}
.mp-links.plain > ul > li {
outline-color: transparent;
}
/***********************
* End main page layout *
************************/
/*********************************************************************************************************************
* Semantically-correct horizontal lists (for Module:Navbox, and they're more machine-readable than {{*}}-formatting) *
**********************************************************************************************************************/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so: */
.hlist dt:not(:last-child)::after {
content: ":\20";
}
.hlist dd:not(:last-child)::after,
.hlist li:not(:last-child)::after {
/* "space, Middle Dot, space"
We use unicode numbers instead of the raw characters due to a Firefox encoding bug on unicode characters.
The space is also encoded because raw spaces combined with a unicode number strips the spaces under some conditions such as single-line lists */
/* content: "\20\00B7\20"; font-weight: bold; */
/* "space • space"
There may (and likely) be an extra whitespace between <li>s,
therefore we have to use a space character as last character of this sequence.
By this way, the last space and the next whitespce will collapse as a single space,
to make the whitespace on both sides of the middle dot the same width.
*/
content: "\20\A0\2022\A0\20";
font-weight: inherit;
}
/* Add parentheses around nested lists */
.hlist dd ol::before,
.hlist dd ul::before,
.hlist dd dl::before,
.hlist dt ol::before,
.hlist dt ul::before,
.hlist dt dl::before,
.hlist li ol::before,
.hlist li ul::before,
.hlist li dl::before {
content: "\20(";
font-weight: inherit;
}
.hlist dd ol::after,
.hlist dd ul::after,
.hlist dd dl::after,
.hlist dt ol::after,
.hlist dt ul::after,
.hlist dt dl::after,
.hlist li ol::after,
.hlist li ul::after,
.hlist li dl::after {
content: ")";
font-weight: inherit;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) ".\20";
}
/* Progressive enhancement:
* try to make the dot always follow the list item in same line
*/
.hlist :is(li,dt,dd):not(:has(:is(li,dt,dd))) {
display: inline-block;
}
/********************************************
* End semantically-correct horizontal lists *
*********************************************/
/*** Miscellaneous ***/
.responsive-image {
max-width: 100%;
height: auto;
}
.view-dark .invert-on-dark,
.view-light .invert-on-light {
filter: invert(100%);
}
.pixelated {
image-rendering: pixelated;
}
@media screen and (min-width: 720px) {
.mobileonly {
display: none;
}
}
@media screen and (max-width: 720px) {
.nomobile {
display: none;
}
}
/*** Utility classes for standard MW galleries ***/
/* it's important that spaced comes before centered in the sheet */
.gallery.gallery.gallery.spaced { /* this selector looks ridiculous but is actually part of stock Vector and therefore a necessary override */
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin-left: unset;
}
.gallery.centered {
text-align: center;
}
/**************************
* Start Modular Templates *
**************************/
/********* [[Template:Ambox]] *********/
.ambox {
--ambox-color: var(--wiki-accent-color);
border: 1px solid var(--wiki-content-border-color);
border-left: 10px solid var(--ambox-color);
border-radius: 2px;
display: flex;
align-items: center;
gap: .6em;
margin: 1em 0;
padding: 3px .6em;
background-color: var(--wiki-content-background-color--secondary);
box-shadow: 2px 2px 5px 0px #0002;
}
@media (min-width: 720px) {
.ambox {
margin-inline: 10%;
}
}
.ambox.tiny {
padding: .04rem .5em;
margin-inline: 0;
width: fit-content;
}
.ambox + .ambox {
margin-top: -.6em;
}
.ambox-content {
flex: 1;
}
.ambox-content p {
margin: .15em 0;
}
.ambox-title {
font-weight: bold;
}
/********* [[Template:Hatnote]] *********/
.hatnote {
padding: 1px 0 1px 1.6em;
margin-bottom: 0.5em;
font-style: italic;
border-top: 1px solid var(--wiki-content-border-color--secondary);
border-bottom: 1px solid var(--wiki-content-border-color--secondary);
}
.hatnote.icon {
padding-left: 0;
}
/********* [[Template:Spoiler]] *********/
.spoiler-content {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 50%, transparent);
transition: all 0.3s;
cursor: pointer;
overflow: auto;
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.spoiler-content {
background-color: var(--wiki-content-dynamic-color--secondary);
}
}
.spoiler-content > * {
pointer-events: none;
opacity: 0;
transition: all 0.3s;
}
.spoiler-content.show {
background-color: transparent;
}
.spoiler-content.show > * {
pointer-events: unset;
opacity: 1;
}
/********* [[Template:Link icon]] *********/
.link-icon {
--link-icon-line-height: 1.5em;
--link-icon-size: 1.5em;
display: inline-flex;
align-items: center;
height: var(--link-icon-line-height);
vertical-align: bottom;
}
.link-icon .regular {
align-self: center;
}
.link-icon .regular a {
display: flex;
}
.link-icon .regular img {
height: var(--link-icon-size);
max-width: var(--link-icon-size);
}
.link-icon .fallback {
outline: 1px solid var(--wiki-content-text-color);
border-radius: 50%;
text-align: center;
width: var(--link-icon-size);
line-height: var(--link-icon-size);
}
.link-icon.notext,
.link-icon.notext .fallback {
display: inline-block;
}
/********* [[Template:Quote]] *********/
.quote {
background: var(--wiki-content-background-color--secondary);
border-radius: 5px;
border: 2px solid var(--wiki-content-border-color);
margin: .5em 0;
padding: .5em;
overflow-y: hidden;
}
.quote .block {
display: block;
}
.quote .title {
font-size: large;
font-weight: bold;
}
.quote .content {
font-style: italic;
}
.quote .author {
font-weight: bold;
text-align: end;
}
.quote .marks-wrapper {
display: flex;
gap: 5px;
}
.quote .marks-wrapper::before,
.quote .marks-wrapper::after {
font-size: 100px;
line-height: 0px;
}
.quote .marks-wrapper::before {
content: "\201C";
margin-top: 40px;
}
.quote .marks-wrapper::after {
content: "\201D";
align-self: end;
margin-bottom: -10px;
}
.client-js .mw-charinsert-item {
display: none;
}
/************************
* End Modular Templates *
*************************/
/*****************************
* Used by [[Template:Color]] *
******************************/
.color__splotch {
display: inline-block;
height: 1em;
width: 1em;
box-sizing: border-box;
vertical-align: text-top;
border-radius: 50%;
border: 1px solid var(--wiki-content-text-color);
}
/*********************
* End Template:Color *
**********************/
/*********************************
* Used by [[Template:TOC limit]] *
**********************************/
.toclimit-2 .toclevel-1 ul,
.toclimit-3 .toclevel-2 ul,
.toclimit-4 .toclevel-3 ul,
.toclimit-5 .toclevel-4 ul,
.toclimit-6 .toclevel-5 ul,
.toclimit-7 .toclevel-6 ul {
display: none;
}
/*************************
* End Template:TOC limit *
**************************/
/*********************************
* Used by [[Template:TOC right]] *
**********************************/
@media all and (min-width: 720px) {
.tocright {
float: right;
clear: right;
margin: 0 0 0.5em 1em;
}
}
/*************************
* End Template:TOC right *
**************************/
811b0c2d2cf7be45e70eb3d56d102f46be473d27
1368
1366
2025-08-25T16:37:46Z
Sharparam
284703
Add background image for light theme
css
text/css
/* CSS placed here will be applied to all skins */
/******************************************************************************************
********************************* Start user-edit variables *******************************
******************************************************************************************/
/*****************************************
****** START BASIC DESIGN VARIABLES ******
----------------------------------------*/
:root {
--wiki-content-heading-font-family: 'Linux Libertine', 'Georgia', 'Times', serif;
--wiki-sidebar-heading-font-family: sans-serif;
--wiki-content-border-radius: 0px;
--wiki-sidebar-border-radius: 0px;
}
/*----------------------------------------
******* END BASIC DESIGN VARIABLES *******
*****************************************/
/*****************************************
****** START BASIC COLOR VARIABLES *******
----------------------------------------*/
:root,
/* Begin light styles, delete from here to "end light styles" if you don't want your wiki to support any light themes (remove from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=light, */
/* individual themes are prefixed with .theme- instead */
.view-light {
/**********************
* Probably edit these * [ LIGHT VIEW ]
***********************/
--wiki-body-background-color: #F6F6F6;
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-content-background-color: #ffffff;
--wiki-content-background-opacity: 100%;
--wiki-content-border-color: #a7d7f9;
--wiki-content-link-color: #0645ad; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ LIGHT VIEW ] */
--wiki-accent-color: #3366cc;
--wiki-accent-label-color: #ffffff;
--wiki-accent-link-color: #D5FB51;
--wiki-icon-to-link-filter: invert(20%) sepia(93%) saturate(2141%) hue-rotate(210deg) brightness(83%) contrast(103%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
/* Site background */
--wiki-body-background-image: url(filepath://Site-background-light.jpg);
--wiki-body-background-position: center;
--wiki-body-background-size: cover;
--wiki-body-background-attachment: fixed;
}
/* end light styles */
/* Begin dark styles, delete from here to "end dark styles" if you don't want your wiki to support any dark themes (remove it from [[Mediawiki:Theme-definitions]] too, or ask wiki.gg staff for help doing this) */
/* FYI: .view- will affect any theme marked |kind=dark, */
/* individual themes are prefixed with .theme- instead */
.view-dark {
/**********************
* Probably edit these * [ DARK VIEW ]
***********************/
--wiki-body-background-color: #171717;
--wiki-body-background-image: url(filepath://Site-background-dark.jpg);
--wiki-content-background-color: #202020;
--wiki-content-background-opacity: 90%;
/* DEFAULT: --wiki-content-border-color: #991A51; */
--wiki-content-border-color: hsl(0deg 0% 30%);
--wiki-content-link-color: #6d8afb; /* if changing this, remember to change --wiki-icon-to-link-filter as well!!! */
/* [ DARK VIEW ] */
/* DEFAULT: --wiki-accent-color: #ff4d9d; */
--wiki-accent-color: hsl(0deg 0% 75%);
--wiki-accent-label-color: #000;
--wiki-accent-link-color: #1e1e43;
--wiki-icon-to-link-filter: invert(60%) sepia(70%) saturate(3715%) hue-rotate(206deg) brightness(101%) contrast(97%); /* put your --wiki-content-link-color into https://mrpie5.gitlab.io/css-filter-generator/ */
/**/
/* Site background */
--wiki-body-background-image: url(filepath://Site-background.jpg);
--wiki-body-background-position: center;
--wiki-body-background-size: cover;
--wiki-body-background-attachment: fixed;
}
/* End dark styles */
/*----------------------------------------
******* END BASIC COLOR VARIABLES ********
*****************************************/
/*****************************************
**** START ADVANCED COLOR VARIABLES ******
----------------------------------------*/
:root,
.view-light {
/*******************
* Maybe edit these * [ LIGHT VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #111111;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #ba0000;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ LIGHT VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ LIGHT VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #bf0017;
--wiki-warning-color: #b05f30;
--wiki-success-color: #0c742f;
/**/
/***********************************
* Likely do not need to edit these * [ LIGHT VIEW ]
************************************/
--wiki-body-dynamic-color: #000000;
--wiki-body-dynamic-color--inverted: #ffffff;
--wiki-body-dynamic-color--secondary: #333333;
--wiki-body-dynamic-color--secondary--inverted: #cccccc;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #ffffff;
--wiki-content-dynamic-color: #000000;
--wiki-content-dynamic-color--inverted: #ffffff;
--wiki-content-dynamic-color--secondary: #333333;
--wiki-content-dynamic-color--secondary--inverted: #cccccc;
/* [ LIGHT VIEW ] */
--wiki-alert-label-color: #ffffff;
--wiki-warning-label-color: #ffffff;
--wiki-success-label-color: #ffffff;
--wiki-icon-general-filter: ; /* do not set this to none, ignore the "unexpected token" error */
/**/
}
.view-dark {
/*******************
* Maybe edit these * [ DARK VIEW ]
********************/
--wiki-body-background-position: top center;
--wiki-body-background-size: cover;
--wiki-body-background-repeat: no-repeat;
--wiki-body-background-attachment: fixed;
--wiki-content-background-color--secondary: color-mix(in srgb, var(--wiki-content-background-color) 96%, var(--wiki-content-dynamic-color));
--wiki-content-text-color: #ededed;
--wiki-content-link-color--visited: var(--wiki-content-link-color);
--wiki-content-link-color--hover: var(--wiki-content-link-color);
--wiki-content-redlink-color: #FC5B4F;
--wiki-content-heading-color: var(--wiki-content-text-color);
--wiki-content-heading-border-color: var(--wiki-content-border-color);
/* [ DARK VIEW ] */
--wiki-navigation-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-border-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-text-color: var(--wiki-content-link-color);
--wiki-navigation-selected-background-color: var(--wiki-content-background-color);
--wiki-navigation-selected-border-color: var(--wiki-content-border-color);
--wiki-navigation-selected-text-color: var(--wiki-content-text-color);
/* [ DARK VIEW ] */
--wiki-neutral-color: var(--wiki-content-text-mix-color);
--wiki-alert-color: #ff576a;
--wiki-warning-color: #cf721c;
--wiki-success-color: #13aa45;
/**/
/***********************************
* Likely do not need to edit these * [ DARK VIEW ]
************************************/
--wiki-body-dynamic-color: #ffffff;
--wiki-body-dynamic-color--inverted: #000000;
--wiki-body-dynamic-color--secondary: #cccccc;
--wiki-body-dynamic-color--secondary--inverted: #333333;
--wiki-content-border-color--secondary: color-mix(in srgb, var(--wiki-content-border-color) 50%, transparent);
--wiki-content-border-color--accent: color-mix(in srgb, var(--wiki-accent-color) 50%, transparent);
--wiki-content-link-label-color: #000;
--wiki-content-dynamic-color: #ffffff;
--wiki-content-dynamic-color--inverted: #000000;
--wiki-content-dynamic-color--secondary: #cccccc;
--wiki-content-dynamic-color--secondary--inverted: #333333;
/* [ DARK VIEW ] */
--wiki-alert-label-color: #000000;
--wiki-warning-label-color: #000000;
--wiki-success-label-color: #000000;
--wiki-icon-general-filter: invert(100%);
}
/*----------------------------------------
***** END ADVANCED COLOR VARIABLES *******
*****************************************/
/*****************************************
**** START ADVANCED DESIGN VARIABLES *****
----------------------------------------*/
:root {
/***********************
start logo position
----------------------*/
--wiki-is-top-logo: 0; /* 1 = center logo at the top of the page; 0 = logo at the top left of the page */
--wiki-logo-file-width: 160; /* Width of the image file in px. Put a number without the letters `px`. */
--wiki-logo-file-height: 160; /* Height of the image file in px. Put a number without the letters `px`. */
--wiki-logo-height: calc(var(--wiki-logo-file-height)*1px); /* Valid only when --wiki-is-top-logo is 1. The height the logo should be shown */
--wiki-logo-margin: 15px; /* the width of margin below the logo. When --wiki-is-top-logo is 1, this is also the default value of --wiki-top-spacing */
/*-----------------------
end logo position
***********************/
--wiki-is-navigation-inside-content: 0; /* 0 = default navigation tabs layout; 1 = navigation tabs inside content box */
--wiki-body-font-family: sans-serif;
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family); /* only apply to the main title of article */
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-width: 1px;
--wiki-sidebar-width: 10em; /* width of sidebar(#mw-panel) */
--wiki-sidebar-portal-spacing: 0px;
--wiki-sidebar-border-width: var(--wiki-content-border-width);
--wiki-navigation-border-radius: 0px; /* border radius of tabs */
/*******************
* Maybe edit these * [ DESIGN ]
********************/
--wiki-logo-filter: none;
/****** the following length variables must have units specified even if 0, ignore the warning *****/
--wiki-content-border-top-radius: var(--wiki-content-border-radius);
--wiki-content-border-style: solid;
--wiki-content-border-image: none;
--wiki-content-backdrop-filter: none;
--wiki-page-content-max-width: 9999px; /* max width of sidebar+gap+content, must be a length value. A huge value can be used to indicate no limit, e.g. 99999px */
--wiki-gap-between-sidebar-and-content: 0.5em; /* gap between sidebar(#mw-panel) and content(#content) */
--wiki-sidebar-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-heading-font-size: 0.75em; /* please use em or rem for this */
--wiki-sidebar-margin: 0.5em;
--wiki-sidebar-list-item-padding: 0.25em 0.25rem;
--wiki-sidebar-list-padding: 0.25rem;
--wiki-sidebar-list-item-background--hover: none; /* background of hover item */
--wiki-navigation-font-size: 0.8125em; /* please use em or rem for this */
--wiki-navigation-height: 2.75rem; /* height of navigation area,include spacing above tabs */
--wiki-navigation-left-spacing: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-radius) + var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-right-spacing: calc( var(--wiki-is-navigation-inside-content) * 0.5rem );
--wiki-navigation-box-background-color: var(--wiki-content-background-color);
--wiki-navigation-box-background-opacity: calc(var(--wiki-content-background-opacity)*0.8*var(--wiki-is-navigation-inside-content));
--wiki-navigation-box-background: color-mix(in srgb, var(--wiki-navigation-box-background-color) var(--wiki-navigation-box-background-opacity), transparent); /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-border-image: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-box-backdrop-filter: none; /* usually only needed when --wiki-is-navigation-inside-content is 1 */
--wiki-navigation-selected-backdrop-filter: var(--wiki-content-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
--wiki-navigation-backdrop-filter: var(--wiki-navigation-selected-backdrop-filter); /* usually only needed when --wiki-is-navigation-inside-content is 0 */
/* nav tabs style. The vector gradient is default.
* If you want to customize the style of tabs, it's easier to start with the following settings:
* --wiki-navigation-background-image: none;
* --wiki-navigation-selected-background-image: none;
* --wiki-navigation-selected-border-width: calc( (1 - var(--wiki-is-navigation-inside-content))*var(--wiki-content-border-width) + var(--wiki-is-navigation-inside-content) * 1px );
* --wiki-navigation-selected-border-bottom-background: none;
* --wiki-navigation-tab-spacing: 0.25em;
* --wiki-navigation-tab-padding-top: 0.5em;
* --wiki-navigation-tab-padding-bottom: 0.5em;
*/
--wiki-navigation-tab-spacing: -1px; /* width of the space between tabs, can be a negative number, in which case adjacent tabs will overlap */
--wiki-navigation-tab-padding-top: 1.25em;
--wiki-navigation-tab-padding-x: 0.75em;
--wiki-navigation-tab-padding-bottom: 4px;
--wiki-navigation-selected-border-width: 0px; /* border width of selected tabs */
--wiki-navigation-border-width: var(--wiki-navigation-selected-border-width); /* border width of normal tabs */
--wiki-navigation-border-image: none;
--wiki-navigation-selected-border-image: var(--wiki-navigation-border-image);
--wiki-navigation-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to top,var(--wiki-navigation-background-color) 0,var(--wiki-navigation-selected-background-color) 100%);
--wiki-navigation-background-repeat: no-repeat, no-repeat, repeat-x;
--wiki-navigation-background-position: left bottom, right bottom, left bottom;
--wiki-navigation-background-size: 1px 100%, 1px 100%, 100%;
--wiki-navigation-selected-background-image: linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%), linear-gradient(to bottom,transparent 0,var(--wiki-content-border-color) 100%);
--wiki-navigation-selected-background-repeat: no-repeat, no-repeat;
--wiki-navigation-selected-background-position: left bottom, right bottom;
--wiki-navigation-selected-background-size: 1px 100%, 1px 100%;
--wiki-navigation-selected-border-bottom-background: linear-gradient(to right, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px), linear-gradient(to left, var(--wiki-content-border-color) 0, var(--wiki-content-border-color) 1px, transparent 1px);
/* affects the dropdown menu under More */
--wiki-navigation-dropdown-text-color: var(--wiki-navigation-text-color);
--wiki-navigation-dropdown-text-color--hover: var(--wiki-navigation-dropdown-text-color);
--wiki-navigation-dropdown-font-size: var(--wiki-navigation-font-size); /* please use em or rem for this */
--wiki-navigation-dropdown-border-width: 1px;
--wiki-navigation-dropdown-border-radius: var(--wiki-navigation-border-radius);
--wiki-navigation-dropdown-padding: 0.25em; /* padding of the dropdown menu box */
--wiki-navigation-dropdown-item-padding: 0.625em; /* padding of each dropdown menu items */
--wiki-navigation-dropdown-item-background--hover: none; /* background of hover item */
--wiki-navigation-dropdown-border-image: none;
--wiki-navigation-dropdown-backdrop-filter: none;
--wiki-navigation-dropdown-box-shadow: none; /* box shadow */
/* styles of the footer */
--wiki-spacing-before-footer: 0px;
--wiki-footer-border-image: none;
/* padding on body element */
--wiki-top-spacing: calc(var(--wiki-is-top-logo)*var(--wiki-logo-margin) + (1 - var(--wiki-is-top-logo))*1em); /* extra spacing below wiki.gg netbar */
--wiki-left-spacing: 0.5em;
--wiki-right-spacing: 1em;
--wiki-bottom-spacing: 2em;
/* end design variables */
}
/*----------------------------------------
***** END ADVANCED DESIGN VARIABLES ******
*****************************************/
/*******************************
**** START SHARED VARIABLES ****
**** tl;dr: don't edit this ****
********************************/
/*
These variables are rarely touched, usually inherit other variables, and are shared on all themes.
In 99% of cases none of these are ever edited, and you should only be doing so if you have a very clear vision,
understand what you are doing, and *know* that what you are trying to do is not accomplished by changing
another variable in the above sections.
Since these are by default shared across all themes, if you support multiple themes you'll probably want to
separate the variables you want to modify here into .view-x blocks like above. If you don't understand
what that means or how to do that then you probably shouldn't be modifying this section.
*/
:root {
--wiki-content-border-bottom-width: var(--wiki-content-border-width);
--wiki-content-border-bottom-style: var(--wiki-content-border-style);
--wiki-content-border-bottom-color: var(--wiki-content-border-color);
--wiki-content-text-mix-color: color-mix(in srgb, var(--wiki-content-background-color), var(--wiki-content-text-color) 62%);
--wiki-content-text-mix-color-95: color-mix(in srgb, var(--wiki-content-background-color) 95%, var(--wiki-content-text-color));
--wiki-content-text-color--hover: var(--wiki-content-text-color);
/* heading */
--wiki-content-heading-border-bottom-width: 1px;
--wiki-content-heading-border-style: solid;
--wiki-content-heading-font-weight: normal;
--wiki-content-heading-font-style: normal;
--wiki-content-heading-text-transform: none;
--wiki-content-heading-line-height: normal;
--wiki-content-heading-text-shadow: none;
/* first heading (h1) */
--wiki-content-firstheading-border-bottom-width: var(--wiki-content-heading-border-bottom-width);
--wiki-content-firstheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-firstheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-firstheading-font-family: var(--wiki-content-heading-font-family);
--wiki-content-firstheading-font-weight: var(--wiki-content-heading-font-weight);
--wiki-content-firstheading-font-style: var(--wiki-content-heading-font-style);
--wiki-content-firstheading-text-transform: var(--wiki-content-heading-text-transform);
--wiki-content-firstheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-firstheading-color: var(--wiki-content-heading-color);
--wiki-content-firstheading-text-shadow: none;
/* sub-heading (h3, h4, h5, h6) */
--wiki-content-subheading-border-bottom-width: 0px;
--wiki-content-subheading-border-style: var(--wiki-content-heading-border-style);
--wiki-content-subheading-border-color: var(--wiki-content-heading-border-color);
--wiki-content-subheading-font-family: var(--wiki-body-font-family);
--wiki-content-subheading-font-weight: bold;
--wiki-content-subheading-font-style: normal;
--wiki-content-subheading-text-transform: none;
--wiki-content-subheading-line-height: var(--wiki-content-heading-line-height);
--wiki-content-subheading-color: var(--wiki-content-heading-color);
--wiki-content-subheading-text-shadow: none;
/* heading size */
--wiki-content-firstheading-font-size: 1.8em;
--wiki-content-heading-h2-font-size: 1.5em;
--wiki-content-heading-h3-font-size: 1.2em;
--wiki-content-heading-h4-font-size: 114%;
--wiki-content-heading-h5-font-size: 108%;
--wiki-content-heading-h6-font-size: 100%;
--wiki-content-toc-background: var(--wiki-content-background-color--secondary);
--wiki-content-toc-border-width: 1px;
--wiki-content-toc-border-style: solid;
--wiki-content-toc-border-color: var(--wiki-content-border-color);
--wiki-content-toc-border-radius: 0px;
--wiki-content-toc-border-image: none;
--wiki-content-toc-box-shadow: 0 0.1em 0.2em #000000;
--wiki-content-catlinks-background: var(--wiki-content-background-color--secondary);
--wiki-content-catlinks-border-width: 1px;
--wiki-content-catlinks-border-style: solid;
--wiki-content-catlinks-border-color: var(--wiki-content-border-color);
--wiki-content-catlinks-border-radius: 0px;
--wiki-content-catlinks-border-image: none;
--wiki-content-catlinks-box-shadow: none;
--wiki-content-filetoc-background: var(--wiki-content-background-color--secondary);
--wiki-content-filetoc-border-width: 1px;
--wiki-content-filetoc-border-style: solid;
--wiki-content-filetoc-border-color: var(--wiki-content-border-color);
--wiki-content-filetoc-border-radius: 0px;
--wiki-content-filetoc-border-image: none;
--wiki-content-filetoc-box-shadow: none;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
--wiki-sidebar-padding: 0px;
--wiki-sidebar-background-color: var(--wiki-content-background-color);
--wiki-sidebar-background-opacity: var(--wiki-content-background-opacity);
--wiki-sidebar-background-image: none;
--wiki-sidebar-background-position: center;
--wiki-sidebar-background-repeat: repeat;
--wiki-sidebar-background-size: auto;
--wiki-sidebar-filter: none;
--wiki-sidebar-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-sidebar-border-color: var(--wiki-content-border-color);
--wiki-sidebar-border-style: solid;
--wiki-sidebar-border-image: none;
--wiki-sidebar-link-color: var(--wiki-content-link-color);
--wiki-sidebar-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-sidebar-heading-color: var(--wiki-content-heading-color);
--wiki-sidebar-heading-font-weight: normal;
--wiki-sidebar-heading-font-style: normal;
--wiki-sidebar-heading-text-transform: none;
--wiki-sidebar-heading-line-height: normal;
--wiki-sidebar-heading-padding: 0.5rem 0.25rem 0.5rem 0.5rem;
--wiki-sidebar-heading-margin: 0px 0px -0.5rem 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-text-shadow: none;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-icon-to-link-filter: var(--wiki-icon-to-link-filter);
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-box-padding: 0px;
--wiki-sidebar-box-background: none;
--wiki-sidebar-box-border: 0px;
--wiki-sidebar-box-border-image: none;
--wiki-accent-color--hover: color-mix(in srgb, var(--wiki-accent-color) 90%, var(--wiki-accent-label-color));
--wiki-footer-border-width: var(--wiki-content-border-width);
--wiki-footer-border-style: var(--wiki-content-border-style);
--wiki-footer-border-color: var(--wiki-content-border-color);
--wiki-footer-background-color: var(--wiki-content-background-color);
--wiki-footer-background-opacity: var(--wiki-content-background-opacity);
--wiki-footer-backdrop-filter: var(--wiki-content-backdrop-filter);
--wiki-footer-text-color: var(--wiki-content-text-color);
--wiki-footer-link-color: var(--wiki-content-link-color);
--wiki-footer-link-color--hover: var(--wiki-content-link-color--hover);
--wiki-footer-border-radius: var(--wiki-content-border-radius);
--wiki-navigation-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-background-color--hover: var(--wiki-navigation-background-color);
--wiki-navigation-background-opacity--hover: var(--wiki-navigation-background-opacity);
--wiki-navigation-background-image--hover: var(--wiki-navigation-background-image);
--wiki-navigation-background-position--hover: var(--wiki-navigation-background-position);
--wiki-navigation-background-repeat--hover: var(--wiki-navigation-background-repeat);
--wiki-navigation-background-size--hover: var(--wiki-navigation-background-size);
--wiki-navigation-text-color--hover: var(--wiki-content-link-color--hover);
--wiki-navigation-transform--hover: none;
--wiki-navigation-selected-border-style: solid;
--wiki-navigation-selected-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-border-style: solid;
--wiki-navigation-border-color--hover: var(--wiki-navigation-border-color);
--wiki-navigation-border-image--hover: var(--wiki-navigation-border-image);
--wiki-navigation-border-bottom-color: var(--wiki-navigation-selected-border-color);
--wiki-navigation-border-bottom-style: var(--wiki-navigation-selected-border-style);
--wiki-navigation-border-bottom-width: calc(var(--wiki-is-navigation-inside-content, 0) * var(--wiki-navigation-selected-border-width, 1px) + (1 - var(--wiki-is-navigation-inside-content, 0)) * var(--wiki-content-border-width, 1px));
--wiki-navigation-icon-size: 1em;
--wiki-navigation-tab-padding-x--icon: var(--wiki-navigation-tab-padding-x);
--wiki-navigation-bottom-spacing: 0px; /* If you change this to greater than 0px, you should usually change the value of --wiki-navigation-selected-border-bottom-background to var(--wiki-navigation-border-bottom-color) */
--wiki-navigation-dropdown-background-color: var(--wiki-navigation-selected-background-color);
--wiki-navigation-dropdown-background-opacity: var(--wiki-content-background-opacity);
--wiki-navigation-dropdown-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-dropdown-offset: 0px; /* vertical offset */
--wiki-navigation-search-background-color: var(--wiki-content-background-color--secondary);
--wiki-navigation-search-background-image: none;
--wiki-navigation-search-background-position: 0;
--wiki-navigation-search-background-size: auto;
--wiki-navigation-search-background-repeat: repeat;
--wiki-navigation-search-backdrop-filter: none;
--wiki-navigation-search-border-color: var(--wiki-navigation-border-color);
--wiki-navigation-search-border-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-border-style: solid;
--wiki-navigation-search-border-width: 1px;
--wiki-navigation-search-border-radius: 2px;
--wiki-navigation-search-border-image: none;
--wiki-navigation-search-border-image--hover: var(--wiki-navigation-search-border-image);
--wiki-navigation-search-box-shadow: none;
--wiki-navigation-search-box-shadow--hover: var(--wiki-navigation-search-box-shadow);
--wiki-navigation-search-text-color: var(--wiki-content-text-color);
--wiki-navigation-search-font-size: var(--wiki-navigation-font-size);
--wiki-navigation-search-height: 2em;
--wiki-navigation-search-button-color: currentColor;
--wiki-navigation-search-button-color--hover: var(--wiki-navigation-search-button-color);
--wiki-navigation-search-button-color-opacity: 80%;
--wiki-navigation-search-button-color-opacity--hover: 95%;
--wiki-navigation-search-bottom-spacing: 3px;
--wiki-navigation-search-highlight-background-color: color-mix(in srgb, var(--wiki-accent-color) 5%, transparent);
--wiki-navigation-gap-between-left-and-right: calc(max(0px, var(--wiki-navigation-tab-spacing))); /* minimum width between #left-navigation and #right-navigation before tabs start to collapse */
}
/*** mobile adjustments ***/
@media screen and (max-width: 720px) {
body.has-vector-mobile-menu{
--wiki-sidebar-offset: 0px; /* Vertical offset */
--wiki-sidebar-margin: 0px;
--wiki-sidebar-heading-background: none;
--wiki-sidebar-heading-border-image: none;
--wiki-sidebar-heading-margin: 0px 0px -0.5em 0px;
--wiki-sidebar-list-margin: 0px;
--wiki-sidebar-list-background: none;
--wiki-sidebar-list-border-image: none;
--wiki-sidebar-list-item-background: none;
--wiki-sidebar-list-item-border-image: none;
--wiki-sidebar-list-item-background--hover: none;
--wiki-sidebar-list-item-border-image--hover: none;
--wiki-sidebar-list-item-spacing: 0px;
--wiki-sidebar-line-height: 1.125;
--wiki-sidebar-background-opacity: 100%;
--wiki-navigation-search-border-width: 1px;
--wiki-logo-offset-x: 0px;
--wiki-logo-offset-y: 0px;
}
}
/*****************************
**** END SHARED VARIABLES ****
******************************/
/******************************************************************************************
********************************* End user-edit variables *********************************
******************************************************************************************/
/******************************
* Fallback for older browsers *
* DONT EDIT THIS *
*******************************/
@supports not (color:color-mix(in srgb, #000, transparent)) {
.view-dark,
.view-light,
:root {
--wiki-content-text-mix-color: var(--wiki-content-text-color);
--wiki-content-text-mix-color-95: var(--wiki-content-background-color);
--wiki-content-background-color--secondary: var(--wiki-content-dynamic-color--secondary--inverted);
--wiki-content-border-color--secondary: var(--wiki-content-border-color);
--wiki-content-border-color--accent: var(--wiki-accent-color);
--wiki-accent-color--hover: var(--wiki-accent-color);
--wiki-navigation-search-highlight-background-color: transparent;
}
}
/*****************************
* End older browser fallback *
******************************/
/*****************************
* PortableInfoboxes *
******************************/
:root {
--pi-background: var(--wiki-content-background-color);
--pi-secondary-background: var(--wiki-accent-color);
--pi-secondary-background-label: var(--wiki-accent-label-color);
--pi-border-color: color-mix(in srgb, var(--pi-secondary-background) 50%, transparent);
}
.portable-infobox .pi-title,
.portable-infobox .pi-header {
text-align: center;
font-size: 1.5em;
background: color-mix(in srgb, var(--pi-secondary-background) 75%, transparent);
color: var(--pi-secondary-background-label);
}
.portable-infobox .pi-data,
.portable-infobox .pi-group {
background: var(--wiki-content-background-color--secondary);
}
.portable-infobox .pi-image {
padding: 8px;
}
.pi-image-thumbnail {
max-width: 100%;
}
.pi-caption {
color: var(--wiki-content-text-mix-color);
}
.pi-section-navigation .pi-section-tab.pi-section-active,
.pi-section-navigation .pi-section-tab.current,
.pi-media-collection .pi-tab-link.current {
background: var(--pi-secondary-background);
color: var(--pi-secondary-background-label);
}
.pi-collapse > .pi-item:first-child {
cursor: pointer;
}
/* overqualify these to overwrite normal content heading styles */
.mw-body .portable-infobox h2,
.mw-body .portable-infobox h3 {
border-bottom: 0;
font-family: inherit;
font-weight: 700;
margin: 0;
}
/*****************************
* End PortableInfoboxes *
******************************/
/*******************
* Main page layout *
********************/
#mp-container {
display: grid;
gap: 10px;
}
@media screen and (max-width: 990px) {
/* for mobile screens */
#mp-container {
grid-template-areas:var(--main-page-layout--mobile);
grid-template-columns:var(--main-page-layout-columns--mobile, 100%);
}
.mp-box.mp-hide-on-mobile {
display: none;
}
}
@media screen and (min-width: 990px) and (max-width: 1350px) {
/* for narrow screens, between 990px and 1350px */
#mp-container {
grid-template-areas:var(--main-page-layout--tablet);
grid-template-columns:var(--main-page-layout-columns--tablet, 1fr 1fr);
}
.mp-box.mp-hide-on-tablet {
display: none;
}
}
@media screen and (min-width: 1350px) {
/* for all other screens, 1350px and wider */
#mp-container {
grid-template-areas:var(--main-page-layout--desktop);
grid-template-columns:var(--main-page-layout-columns--desktop, 2fr 1fr 2fr);
}
.mp-box.mp-hide-on-desktop {
display: none;
}
}
.mp-box {
position: relative;
display: flex;
flex-flow: column nowrap;
width: 100%;
box-sizing: border-box;
background: color-mix(in srgb, var(--wiki-content-background-color--secondary) 25%, transparent);
border: 1px solid var(--wiki-content-border-color);
padding: 0px;
}
.mp-body {
height: 100%;
display: flex;
padding: 0.5em;
flex-flow: column nowrap;
}
.mp-box.centered-content .mp-body {
height: 100%;
display: flex;
flex-flow: column nowrap;
justify-content: space-evenly;
}
.mp-box.has-floating-image {
display: block;
}
.mp-box.has-floating-image .mp-body {
height: unset;
display: block;
}
/* overqualified to override normal heading styles */
.mw-body .mp-box h2 {
text-align: center;
font-weight: bold;
font-family: var(--wiki-content-heading-font-family);
overflow: initial;
border-bottom: 1px solid var(--wiki-content-border-color);
font-size: 150%;
margin: 0;
padding: 5px 0;
color: var(--wiki-content-heading-color);
}
#mp-box-welcome {
text-align: center;
position: relative;
overflow: hidden;
}
#mp-box-welcome h2 {
font-size: 200%;
}
#mp-welcome {
display: flex;
flex-flow: column nowrap;
position: relative;
height: 100%;
z-index: 2;
box-sizing: border-box;
}
#mp-welcome .welcome-subtitle {
height: 100%;
background: color-mix(in srgb, var(--wiki-content-dynamic-color--inverted) 85%, transparent);
padding: 0.5em;
}
#mp-banner {
position: absolute;
width: 100%;
height: 100%;
filter: blur(5px);
z-index: -1;
background: url(/images/e/e0/MP_banner.jpg);
background-size: cover;
background-repeat: no-repeat;
background-position: top center;
}
.view-dark #mp-banner {
filter: blur(5px) brightness(50%);
}
.view-light #mp-banner {
filter: blur(5px) contrast(50%);
}
/* [[Template:MP_link]] */
.mp-links {
--gap: 10px;
}
.mp-links > ul {
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin: 2px;
gap: var(--gap);
}
.mp-links > ul > li {
display: flex;
flex-flow: column nowrap;
align-items: stretch;
text-align: center;
box-sizing: border-box;
flex: max(calc(50% - var(--gap)), 5em) 1 1;
outline: 1px solid var(--wiki-content-link-color);
transition: 0.1s ease-in;
}
.mp-links > ul > li:hover {
background-color: color-mix(in srgb, var(--wiki-content-link-color) 20%, transparent);
}
.mp-links.columns-1 > ul > li {flex: max(calc(100% - var(--gap)), 5em) 1 1;}
.mp-links.columns-2 > ul > li {flex: max(calc(50% - var(--gap)), 5em) 1 1;}
.mp-links.columns-3 > ul > li {flex: max(calc((100% / 3) - var(--gap)), 5em) 1 1;}
.mp-links.columns-4 > ul > li {flex: max(calc(25% - var(--gap)), 5em) 1 1;}
.mp-links.columns-5 > ul > li {flex: max(calc(20% - var(--gap)), 5em) 1 1;}
.mp-links.columns-6 > ul > li {flex: max(calc((100% / 6) - var(--gap)), 5em) 1 1;}
.mp-links.columns-7 > ul > li {flex: max(calc((100% / 7) - var(--gap)), 5em) 1 1;}
.mp-links.columns-8 > ul > li {flex: max(calc((100% / 8) - var(--gap)), 5em) 1 1;}
.mp-links.columns-max > ul > li {flex: max(calc(0% - var(--gap)), 5em) 1 1;}
.mp-links > ul > li:hover a {
text-decoration: underline;
}
.mp-links > ul > li > a {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
flex: 1 1 auto;
box-sizing: border-box;
padding: 5px;
}
.mp-links > ul > li > a:first-child {
height: 100%;
}
.mp-links > ul > li > a:last-child:not(:first-child) {
height: unset;
}
.mp-links.stretch,
.mp-links.stretch > ul {
height: 100%;
}
.mp-links.side-image li {
flex-flow: row nowrap;
}
.mp-links.plain > ul > li {
outline-color: transparent;
}
/***********************
* End main page layout *
************************/
/*********************************************************************************************************************
* Semantically-correct horizontal lists (for Module:Navbox, and they're more machine-readable than {{*}}-formatting) *
**********************************************************************************************************************/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so: */
.hlist dt:not(:last-child)::after {
content: ":\20";
}
.hlist dd:not(:last-child)::after,
.hlist li:not(:last-child)::after {
/* "space, Middle Dot, space"
We use unicode numbers instead of the raw characters due to a Firefox encoding bug on unicode characters.
The space is also encoded because raw spaces combined with a unicode number strips the spaces under some conditions such as single-line lists */
/* content: "\20\00B7\20"; font-weight: bold; */
/* "space • space"
There may (and likely) be an extra whitespace between <li>s,
therefore we have to use a space character as last character of this sequence.
By this way, the last space and the next whitespce will collapse as a single space,
to make the whitespace on both sides of the middle dot the same width.
*/
content: "\20\A0\2022\A0\20";
font-weight: inherit;
}
/* Add parentheses around nested lists */
.hlist dd ol::before,
.hlist dd ul::before,
.hlist dd dl::before,
.hlist dt ol::before,
.hlist dt ul::before,
.hlist dt dl::before,
.hlist li ol::before,
.hlist li ul::before,
.hlist li dl::before {
content: "\20(";
font-weight: inherit;
}
.hlist dd ol::after,
.hlist dd ul::after,
.hlist dd dl::after,
.hlist dt ol::after,
.hlist dt ul::after,
.hlist dt dl::after,
.hlist li ol::after,
.hlist li ul::after,
.hlist li dl::after {
content: ")";
font-weight: inherit;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) ".\20";
}
/* Progressive enhancement:
* try to make the dot always follow the list item in same line
*/
.hlist :is(li,dt,dd):not(:has(:is(li,dt,dd))) {
display: inline-block;
}
/********************************************
* End semantically-correct horizontal lists *
*********************************************/
/*** Miscellaneous ***/
.responsive-image {
max-width: 100%;
height: auto;
}
.view-dark .invert-on-dark,
.view-light .invert-on-light {
filter: invert(100%);
}
.pixelated {
image-rendering: pixelated;
}
@media screen and (min-width: 720px) {
.mobileonly {
display: none;
}
}
@media screen and (max-width: 720px) {
.nomobile {
display: none;
}
}
/*** Utility classes for standard MW galleries ***/
/* it's important that spaced comes before centered in the sheet */
.gallery.gallery.gallery.spaced { /* this selector looks ridiculous but is actually part of stock Vector and therefore a necessary override */
display: flex;
flex-flow: row wrap;
justify-content: space-evenly;
margin-left: unset;
}
.gallery.centered {
text-align: center;
}
/**************************
* Start Modular Templates *
**************************/
/********* [[Template:Ambox]] *********/
.ambox {
--ambox-color: var(--wiki-accent-color);
border: 1px solid var(--wiki-content-border-color);
border-left: 10px solid var(--ambox-color);
border-radius: 2px;
display: flex;
align-items: center;
gap: .6em;
margin: 1em 0;
padding: 3px .6em;
background-color: var(--wiki-content-background-color--secondary);
box-shadow: 2px 2px 5px 0px #0002;
}
@media (min-width: 720px) {
.ambox {
margin-inline: 10%;
}
}
.ambox.tiny {
padding: .04rem .5em;
margin-inline: 0;
width: fit-content;
}
.ambox + .ambox {
margin-top: -.6em;
}
.ambox-content {
flex: 1;
}
.ambox-content p {
margin: .15em 0;
}
.ambox-title {
font-weight: bold;
}
/********* [[Template:Hatnote]] *********/
.hatnote {
padding: 1px 0 1px 1.6em;
margin-bottom: 0.5em;
font-style: italic;
border-top: 1px solid var(--wiki-content-border-color--secondary);
border-bottom: 1px solid var(--wiki-content-border-color--secondary);
}
.hatnote.icon {
padding-left: 0;
}
/********* [[Template:Spoiler]] *********/
.spoiler-content {
background-color: color-mix(in srgb, var(--wiki-content-dynamic-color) 50%, transparent);
transition: all 0.3s;
cursor: pointer;
overflow: auto;
}
@supports not (color:color-mix(in srgb, #000, transparent)) {
.spoiler-content {
background-color: var(--wiki-content-dynamic-color--secondary);
}
}
.spoiler-content > * {
pointer-events: none;
opacity: 0;
transition: all 0.3s;
}
.spoiler-content.show {
background-color: transparent;
}
.spoiler-content.show > * {
pointer-events: unset;
opacity: 1;
}
/********* [[Template:Link icon]] *********/
.link-icon {
--link-icon-line-height: 1.5em;
--link-icon-size: 1.5em;
display: inline-flex;
align-items: center;
height: var(--link-icon-line-height);
vertical-align: bottom;
}
.link-icon .regular {
align-self: center;
}
.link-icon .regular a {
display: flex;
}
.link-icon .regular img {
height: var(--link-icon-size);
max-width: var(--link-icon-size);
}
.link-icon .fallback {
outline: 1px solid var(--wiki-content-text-color);
border-radius: 50%;
text-align: center;
width: var(--link-icon-size);
line-height: var(--link-icon-size);
}
.link-icon.notext,
.link-icon.notext .fallback {
display: inline-block;
}
/********* [[Template:Quote]] *********/
.quote {
background: var(--wiki-content-background-color--secondary);
border-radius: 5px;
border: 2px solid var(--wiki-content-border-color);
margin: .5em 0;
padding: .5em;
overflow-y: hidden;
}
.quote .block {
display: block;
}
.quote .title {
font-size: large;
font-weight: bold;
}
.quote .content {
font-style: italic;
}
.quote .author {
font-weight: bold;
text-align: end;
}
.quote .marks-wrapper {
display: flex;
gap: 5px;
}
.quote .marks-wrapper::before,
.quote .marks-wrapper::after {
font-size: 100px;
line-height: 0px;
}
.quote .marks-wrapper::before {
content: "\201C";
margin-top: 40px;
}
.quote .marks-wrapper::after {
content: "\201D";
align-self: end;
margin-bottom: -10px;
}
.client-js .mw-charinsert-item {
display: none;
}
/************************
* End Modular Templates *
*************************/
/*****************************
* Used by [[Template:Color]] *
******************************/
.color__splotch {
display: inline-block;
height: 1em;
width: 1em;
box-sizing: border-box;
vertical-align: text-top;
border-radius: 50%;
border: 1px solid var(--wiki-content-text-color);
}
/*********************
* End Template:Color *
**********************/
/*********************************
* Used by [[Template:TOC limit]] *
**********************************/
.toclimit-2 .toclevel-1 ul,
.toclimit-3 .toclevel-2 ul,
.toclimit-4 .toclevel-3 ul,
.toclimit-5 .toclevel-4 ul,
.toclimit-6 .toclevel-5 ul,
.toclimit-7 .toclevel-6 ul {
display: none;
}
/*************************
* End Template:TOC limit *
**************************/
/*********************************
* Used by [[Template:TOC right]] *
**********************************/
@media all and (min-width: 720px) {
.tocright {
float: right;
clear: right;
margin: 0 0 0.5em 1em;
}
}
/*************************
* End Template:TOC right *
**************************/
4a7903762df7411b028fa7d0ce46dca67d0559d5
File:Site-background-light.jpg
6
863
1367
2025-08-25T16:37:03Z
Sharparam
284703
From the SteamDB screenshots page: https://steamdb.info/app/1173220/screenshots/
wikitext
text/x-wiki
== Summary ==
From the SteamDB screenshots page: https://steamdb.info/app/1173220/screenshots/
== Licensing ==
{{License|game}}
e1998ae6a00a7eb247838ce82b0e75517d54eb6d
1370
1367
2025-08-25T16:44:22Z
Sharparam
284703
Protected "[[File:Site-background-light.jpg]]": Part of skin ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite) [Upload=Allow only administrators] (indefinite))
wikitext
text/x-wiki
== Summary ==
From the SteamDB screenshots page: https://steamdb.info/app/1173220/screenshots/
== Licensing ==
{{License|game}}
e1998ae6a00a7eb247838ce82b0e75517d54eb6d
Template:Date
10
864
1371
2025-08-25T20:40:38Z
Sharparam
284703
Created page with "{{#vardefine:format|{{#switch:{{lc:{{{2}}}}} | iso = Y-m-d | dmy | rfc = j M Y | #default = {{{2|Y-m-d}}} }} }}<!-- -->{{#vardefine:dto|{{{1|now}}}}}<!-- --><time datetime="{{#time: Y-m-d|{{#var:dto}}}}"><!-- -->{{#time: {{#var:format}}|{{#var:dto}}}}<!-- --></time><noinclude> {{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#vardefine:format|{{#switch:{{lc:{{{2}}}}}
| iso = Y-m-d
| dmy
| rfc = j M Y
| #default = {{{2|Y-m-d}}}
}}
}}<!--
-->{{#vardefine:dto|{{{1|now}}}}}<!--
--><time datetime="{{#time: Y-m-d|{{#var:dto}}}}"><!--
-->{{#time: {{#var:format}}|{{#var:dto}}}}<!--
--></time><noinclude>
{{Documentation}}</noinclude>
69a10f946cbad0362ff4fff45fadc1ccba0232df
Template:Date/doc
10
865
1372
2025-08-25T20:51:51Z
Sharparam
284703
Created page with "Produces a properly formatted date in wiki articles. The output will be wrapped in a {{tag|time}} HTML tag where an ISO date is put in the <code>datetime</code> attribute, while the rendered format can be customized by using the second parameter of the template. For consistent reading of wikitext source, it is recommended to use ISO 8601 format for the input date parameter. == TemplateData == <templatedata> { "params": { "1": { "label": "Date object", "descr..."
wikitext
text/x-wiki
Produces a properly formatted date in wiki articles.
The output will be wrapped in a {{tag|time}} HTML tag where an ISO date is put in the <code>datetime</code> attribute, while the rendered format can be customized by using the second parameter of the template.
For consistent reading of wikitext source, it is recommended to use ISO 8601 format for the input date parameter.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Date object",
"description": "The date object to format.",
"example": "2025-08-25",
"type": "line",
"default": "now",
"suggested": true
},
"2": {
"label": "Format",
"description": "The format to use to display the time.",
"example": "ISO",
"type": "line",
"suggestedvalues": [
"ISO",
"RFC"
],
"default": "ISO"
}
},
"description": "Produces a properly formatted date string",
"paramOrder": [
"1",
"2"
],
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Date}}</syntaxhighlight> → {{Date}}
* <syntaxhighlight lang="wikitext" inline>{{Date|2023-05-16}}</syntaxhighlight> → {{Date|2023-05-16}}
* <syntaxhighlight lang="wikitext" inline>{{Date||RFC}}</syntaxhighlight> → {{Date||RFC}}
* <syntaxhighlight lang="wikitext" inline>{{Date|2008 5 aug}}</syntaxhighlight> → {{Date|2008 5 aug}}
* <syntaxhighlight lang="wikitext" inline>{{Date|2012 9 apr|RFC}}</syntaxhighlight> → {{Date|2012 9 apr|RFC}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
851c165169cef35e22cd434843b54d8bbe4ad696
Template:Time
10
866
1373
2025-08-25T21:34:21Z
Sharparam
284703
Created page with "{{#vardefine:time|{{{1|14:00}}}}}<!-- -->{{#vardefine:format|{{#switch:{{lc:{{{2}}}}} | hm = H:i | hmo = H:iP | hms = H:i:s | hmso = H:i:sP | #default = {{{2|H:i}}} }} }}<!-- --><time datetime="{{#time:H:i:sP|{{#var:time}}}}"><!-- -->{{#time:{{#var:format}}|{{#var:time}}}}<!-- --></time><!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#vardefine:time|{{{1|14:00}}}}}<!--
-->{{#vardefine:format|{{#switch:{{lc:{{{2}}}}}
| hm = H:i
| hmo = H:iP
| hms = H:i:s
| hmso = H:i:sP
| #default = {{{2|H:i}}}
}}
}}<!--
--><time datetime="{{#time:H:i:sP|{{#var:time}}}}"><!--
-->{{#time:{{#var:format}}|{{#var:time}}}}<!--
--></time><!--
--><noinclude>{{Documentation}}</noinclude>
29da45daa0ccdc5ffb03e1c4f95a16956eb3ef41
1376
1373
2025-08-25T21:56:17Z
Sharparam
284703
Fix default value
wikitext
text/x-wiki
{{#vardefine:time|{{{1|now}}}}}<!--
-->{{#vardefine:format|{{#switch:{{lc:{{{2}}}}}
| hm = H:i
| hmo = H:iP
| hms = H:i:s
| hmso = H:i:sP
| #default = {{{2|H:i}}}
}}
}}<!--
--><time datetime="{{#time:H:i:sP|{{#var:time}}}}"><!--
-->{{#time:{{#var:format}}|{{#var:time}}}}<!--
--></time><!--
--><noinclude>{{Documentation}}</noinclude>
c1fe1669143f52a06573a8f71b02446b5398347e
Template:Time/doc
10
867
1374
2025-08-25T21:53:19Z
Sharparam
284703
Created page with "Displays properly formatted time (no date). The output is wrapped in a {{tag|time}} tag so that the <code>datetime</code> attribute contains properly formatted time with offset. Note that this works differently from the Wikipedia [[wikipedia:Template:Time|]], as the Wikipedia version displays date {{em|and}} time. For date and time combined, use the {{tl|Datetime}} template. For now, this template requires well-formatted input. In the future, it might become more leni..."
wikitext
text/x-wiki
Displays properly formatted time (no date). The output is wrapped in a {{tag|time}} tag so that the <code>datetime</code> attribute contains properly formatted time with offset.
Note that this works differently from the Wikipedia [[wikipedia:Template:Time|Template:Time]], as the Wikipedia version displays date {{em|and}} time.
For date and time combined, use the {{tl|Datetime}} template.
For now, this template requires well-formatted input. In the future, it might become more lenient to accept other input forms and convert it to well-formed output. The input only supports UTC time for now.
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Time}}</syntaxhighlight> → {{Time}}
* <syntaxhighlight lang="wikitext" inline>{{Time|14:00}}</syntaxhighlight> → {{Time|14:00}}
* <syntaxhighlight lang="wikitext" inline>{{Time|13:37|HMS}}</syntaxhighlight> → {{Time|13:37|HMS}}
* <syntaxhighlight lang="wikitext" inline>{{Time|12:00|HMO}}</syntaxhighlight> → {{Time|12:00|HMO}}
* <syntaxhighlight lang="wikitext" inline>{{Time|09:32:10|HMSO}}</syntaxhighlight> → {{Time|09:32:10|HMSO}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
72e4c662859a7ab7b64ff054e794b3a1f7bffd02
1375
1374
2025-08-25T21:55:45Z
Sharparam
284703
Add TemplateData
wikitext
text/x-wiki
Displays properly formatted time (no date). The output is wrapped in a {{tag|time}} tag so that the <code>datetime</code> attribute contains properly formatted time with offset.
Note that this works differently from the Wikipedia [[wikipedia:Template:Time|Template:Time]], as the Wikipedia version displays date {{em|and}} time.
For date and time combined, use the {{tl|Datetime}} template.
For now, this template requires well-formatted input. In the future, it might become more lenient to accept other input forms and convert it to well-formed output. The input only supports UTC time for now.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Time",
"description": "The time to format.",
"example": "13:37",
"type": "line",
"default": "now",
"suggested": true
},
"2": {
"label": "Format",
"description": "How to format the displayed time. An \"O\" at the end will show the UTC offset (currently always 0).",
"example": "HMS",
"type": "line",
"suggestedvalues": [
"HMS",
"HMSO",
"HM",
"HMO"
],
"default": "HM"
}
},
"description": "Displays formatted time.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Time}}</syntaxhighlight> → {{Time}}
* <syntaxhighlight lang="wikitext" inline>{{Time|14:00}}</syntaxhighlight> → {{Time|14:00}}
* <syntaxhighlight lang="wikitext" inline>{{Time|13:37|HMS}}</syntaxhighlight> → {{Time|13:37|HMS}}
* <syntaxhighlight lang="wikitext" inline>{{Time|12:00|HMO}}</syntaxhighlight> → {{Time|12:00|HMO}}
* <syntaxhighlight lang="wikitext" inline>{{Time|09:32:10|HMSO}}</syntaxhighlight> → {{Time|09:32:10|HMSO}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
69b056ff8cd2593206dcaad106fb0de3821c556c
Template:Datetime
10
868
1377
2025-08-27T18:14:06Z
Sharparam
284703
Created page with "{{#vardefine:dto|{{{1|now}}}}}<!-- -->{{#vardefine:format|{{#switch:{{lc:{{{2}}}}} | iso = Y-m-d H:i{{#if:{{Yesno|{{{seconds|}}}}}|:s}}{{#if:{{Yesno|{{{offset|}}}}}|+00:00}} | rfc | #default = {{{2|D, j M Y H:i{{#if:{{Yesno|{{{seconds|}}}}}|:s}}{{#if:{{Yesno|{{{offset|}}}}}|+0000}}}}} }}}}<!-- --><time datetime="{{#time:c|{{#var:dto}}}}"><!-- -->{{#time:{{#var:format}}|{{#var:dto}}}}<!-- --></time><!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#vardefine:dto|{{{1|now}}}}}<!--
-->{{#vardefine:format|{{#switch:{{lc:{{{2}}}}}
| iso = Y-m-d H:i{{#if:{{Yesno|{{{seconds|}}}}}|:s}}{{#if:{{Yesno|{{{offset|}}}}}|+00:00}}
| rfc
| #default = {{{2|D, j M Y H:i{{#if:{{Yesno|{{{seconds|}}}}}|:s}}{{#if:{{Yesno|{{{offset|}}}}}|+0000}}}}}
}}}}<!--
--><time datetime="{{#time:c|{{#var:dto}}}}"><!--
-->{{#time:{{#var:format}}|{{#var:dto}}}}<!--
--></time><!--
--><noinclude>{{Documentation}}</noinclude>
ee01e3f343e8a1b1df09400b4cf410beaf9afc11
1379
1377
2025-08-27T18:39:25Z
Sharparam
284703
Improve options
wikitext
text/x-wiki
{{#vardefine:dto|{{{1|now}}}}}<!--
-->{{#vardefine:format|{{#switch:{{lc:{{{2}}}}}
| iso = Y-m-d H:i{{Yesno|{{{seconds|}}}|yes=\:s}}" UTC"
| rfc
| #default = {{Yesno|{{{weekday|yes}}}|yes=D," "}}j M Y H:i{{Yesno|{{{seconds|}}}|yes=\:s}}" UTC"
}}}}<!--
--><time datetime="{{#time:c|{{#var:dto}}}}"><!--
-->{{#time:{{#var:format}}|{{#var:dto}}}}<!--
--></time><!--
--><noinclude>{{Documentation}}</noinclude>
57bb4bc267f7c3a6089e627dffb9cefed991c706
Template:Datetime/doc
10
869
1378
2025-08-27T18:26:26Z
Sharparam
284703
Created page with "Formats a given input date (and time) according to wiki standards. If no date is given it will use the current date and time. If no time is given it will use midnight. Output is always in UTC (for now), but input can be any offset as long as it is specified. Currently, only ISO and RFC formats are supported, to ensure datetime strings across the wiki are consistent. The RFC format is likely more readable in article body text, while the ISO format might be more suitable..."
wikitext
text/x-wiki
Formats a given input date (and time) according to wiki standards. If no date is given it will use the current date and time. If no time is given it will use midnight.
Output is always in UTC (for now), but input can be any offset as long as it is specified.
Currently, only ISO and RFC formats are supported, to ensure datetime strings across the wiki are consistent. The RFC format is likely more readable in article body text, while the ISO format might be more suitable in places like infoboxes or table data since it is more compact.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Datetime",
"description": "The date and time to format.",
"example": "2025-08-27 13:37",
"type": "date",
"default": "now",
"suggested": true
},
"2": {
"label": "Format",
"description": "How to format the date.",
"example": "rfc",
"type": "line",
"suggestedvalues": [
"iso",
"rfc"
],
"default": "rfc"
},
"seconds": {
"label": "Seconds",
"description": "Whether to include seconds in formatted display.",
"example": "yes",
"type": "boolean",
"default": "no"
}
},
"description": "Formats a date with time component.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Datetime}}</syntaxhighlight> → {{Datetime}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2023-07-12}}</syntaxhighlight> → {{Datetime|2023-07-12}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2024-10-05 13:37}}</syntaxhighlight> → {{Datetime|2024-10-05 13:37}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2020-12-12 16:20+01:00}}</syntaxhighlight> → {{Datetime|2020-12-12 16:20+01:00}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2005-03-28 05:48:33|seconds=yes}}</syntaxhighlight> → {{Datetime|2005-03-28 05:48:33|seconds=yes}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||iso}}</syntaxhighlight> → {{Datetime||iso}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||rfc}}</syntaxhighlight> → {{Datetime||rfc}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
29706c7760147a2125de6dfeaaaea7d5dc53e05e
1380
1378
2025-08-27T18:41:35Z
Sharparam
284703
Document weekday parameter and add more examples
wikitext
text/x-wiki
Formats a given input date (and time) according to wiki standards. If no date is given it will use the current date and time. If no time is given it will use midnight.
Output is always in UTC (for now), but input can be any offset as long as it is specified.
Currently, only ISO and RFC formats are supported, to ensure datetime strings across the wiki are consistent. The RFC format is likely more readable in article body text, while the ISO format might be more suitable in places like infoboxes or table data since it is more compact.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Datetime",
"description": "The date and time to format.",
"example": "2025-08-27 13:37",
"type": "date",
"default": "now",
"suggested": true
},
"2": {
"label": "Format",
"description": "How to format the date.",
"example": "rfc",
"type": "line",
"suggestedvalues": [
"iso",
"rfc"
],
"default": "rfc"
},
"seconds": {
"label": "Seconds",
"description": "Whether to include seconds in formatted display.",
"example": "yes",
"type": "boolean",
"default": "no"
},
"weekday": {
"label": "Weekday (RFC)",
"description": "Show weekday when using RFC format.",
"example": "no",
"type": "boolean",
"default": "yes"
}
},
"description": "Formats a date with time component.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Datetime}}</syntaxhighlight> → {{Datetime}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2023-07-12}}</syntaxhighlight> → {{Datetime|2023-07-12}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2024-10-05 13:37}}</syntaxhighlight> → {{Datetime|2024-10-05 13:37}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2020-12-12 16:20+01:00}}</syntaxhighlight> → {{Datetime|2020-12-12 16:20+01:00}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2005-03-28 05:48:33|seconds=yes}}</syntaxhighlight> → {{Datetime|2005-03-28 05:48:33|seconds=yes}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2023-07-12|weekday=no}}</syntaxhighlight> → {{Datetime|2023-07-12|weekday=no}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||iso}}</syntaxhighlight> → {{Datetime||iso}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||iso|seconds=yes}}</syntaxhighlight> → {{Datetime||iso}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||rfc}}</syntaxhighlight> → {{Datetime||rfc}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
7e4c510ec7e75db86e673727c7d89720d1b2c47c
1381
1380
2025-08-27T18:43:36Z
Sharparam
284703
Fix missing parameter in rendered example
wikitext
text/x-wiki
Formats a given input date (and time) according to wiki standards. If no date is given it will use the current date and time. If no time is given it will use midnight.
Output is always in UTC (for now), but input can be any offset as long as it is specified.
Currently, only ISO and RFC formats are supported, to ensure datetime strings across the wiki are consistent. The RFC format is likely more readable in article body text, while the ISO format might be more suitable in places like infoboxes or table data since it is more compact.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Datetime",
"description": "The date and time to format.",
"example": "2025-08-27 13:37",
"type": "date",
"default": "now",
"suggested": true
},
"2": {
"label": "Format",
"description": "How to format the date.",
"example": "rfc",
"type": "line",
"suggestedvalues": [
"iso",
"rfc"
],
"default": "rfc"
},
"seconds": {
"label": "Seconds",
"description": "Whether to include seconds in formatted display.",
"example": "yes",
"type": "boolean",
"default": "no"
},
"weekday": {
"label": "Weekday (RFC)",
"description": "Show weekday when using RFC format.",
"example": "no",
"type": "boolean",
"default": "yes"
}
},
"description": "Formats a date with time component.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Datetime}}</syntaxhighlight> → {{Datetime}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2023-07-12}}</syntaxhighlight> → {{Datetime|2023-07-12}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2024-10-05 13:37}}</syntaxhighlight> → {{Datetime|2024-10-05 13:37}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2020-12-12 16:20+01:00}}</syntaxhighlight> → {{Datetime|2020-12-12 16:20+01:00}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2005-03-28 05:48:33|seconds=yes}}</syntaxhighlight> → {{Datetime|2005-03-28 05:48:33|seconds=yes}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime|2023-07-12|weekday=no}}</syntaxhighlight> → {{Datetime|2023-07-12|weekday=no}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||iso}}</syntaxhighlight> → {{Datetime||iso}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||iso|seconds=yes}}</syntaxhighlight> → {{Datetime||iso|seconds=yes}}
* <syntaxhighlight lang="wikitext" inline>{{Datetime||rfc}}</syntaxhighlight> → {{Datetime||rfc}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
2b120d6e34b188f18aff214200d2f11165f5ccd6
Meta:Manual of Style
4
845
1382
1348
2025-08-27T18:52:45Z
Sharparam
284703
/* Formatting */ Add guideline for dates and time
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
== Layout ==
Overall, follow the same layout guidelines as used on Wikipedia ([[wikipedia:Wikipedia:Manual of Style/Layout|Wikipedia:Manual of Style/Layout]]).
This wiki has some common sections that do not appear on Wikipedia though, like <q>Location(s)</q>, <q>Acquisition</q>, and <q>Trivia</q>.
=== Location and acquisition ===
These are important sections and often what readers are interested in when looking up an item for example.
As such, they should appear early, but after the main body content of an article, so usually following the <q>Overview</q> section (if present).
=== Bugs ===
The bugs section is considered part of the appendices, and should appear as the first appendix item following the main content of an article.
=== Trivia ===
The trivia section is considered part of the appendices, and should appear after [[#Bugs|Bugs]].
=== Other sections ===
Sometimes it can be useful to divide an article into more unique sections, like how location articles will have sections listing items, enemies, bosses, and NPCs.
Use your best judgment for where these should be placed, as long as they come after the <q>Overview</q> section.
== Formatting ==
=== Emphasis ===
Due to how Wikitext works, using single quotes to produce italics, bold, or bolded italics (<code><nowiki>''...''</nowiki></code>, <code><nowiki>'''...'''</nowiki></code>, and <code><nowiki>'''''...'''''</nowiki></code>) results in simple typographical styles (with the HTML {{tag|i|open}} and {{tag|b|open}} tags).
When {{em|semantic}} emphasis is what is desired, use the {{tl|Em}} template to produce it (or the {{tag|em}} HTML tag, but the template should be more convenient).
For strong semantic emphasis, use the {{tl|Strong}} template which uses the {{tag|strong}} HTML tag.
=== Date and time ===
In order to have dates and time be consistent across the wiki, there are a few templates to help:
;{{tl|Date}}
:For just a date with no associated time.
;{{tl|Time}}
:For just a time with no associated date.
;{{tl|Datetime}}
:When both date and time are needed.
The templates are currently only able to output dates and times adjusted to UTC (e.g., if you give {{tl|Datetime}} an input of <code>2025-08-27 20:48+02:00</code>, it will render as "{{Datetime|2025-08-27 20:48+02:00}}").
In the future, the templates might be condensed down to a single one that can handle different variants of dates and/or time with support for rendering differerent timezones.
The Wikipedia date/time templates were specifically {{em|not}} copied to this wiki because they do not render into a {{tag|time}} element which makes them worse for accessibility and semantics.
== Infoboxes ==
Infoboxes are very useful to allow readers to quickly see important information in a structured manner that will be consistent between articles. They also help to apply categories to a page.
The following types of articles must have an infobox:
* NPCs ({{tl|Infobox/NPC}})
* Enemies ({{tl|Infobox/Enemy}})
* Bosses ({{tl|Infobox/Boss}})
* Items ({{tl|Infobox/Item}})
** Weapons ({{tl|Infobox/Weapon}})
** Armor ({{tl|Infobox/Armor}})
** Capes ({{tl|Infobox/Cape}})
** Shields ({{tl|Infobox/Shield}})
** Armor set ({{tl|Infobox/Armor set}})
** Amulets ({{tl|Infobox/Amulet}})
* Abilities ({{tl|Infobox/Ability}})
* Passives ({{tl|Infobox/Passive}})
There may be other infoboxes not covered in this manual, the [[:Category:Infobox templates|infobox templates category]] will list all the currently existing infobox templates.
The base {{ml|Infobox}} module should {{strong|never}} be used in an article. It is only used to create more specialized infoboxes.
(Though you can use it to spice up your user page if you want, just don't use it in mainspace content.)
When possible, the image used in the infobox should be an asset extracted from the game. When not possible, take a screenshot in the game and make sure the subject is clearly visible and isolated from unrelated objects with the background as clean as you can manage.
Keep in mind that infobox images will be sized to 300 pixels wide. (Some game assets are smaller than 300 pixels, and then there isn't much you can do, so just allow it to stretch.)
Infoboxes should be put at the top of an article, before the lead text.
== Navboxes ==
Navboxes (or navigation boxes) are put at the end of articles (before any categories) to help readers navigate between related content, like weapons.
See the [[:Category:Navigation templates|navigation templates category]] for currently existing navboxes.
Use the navbox most relevant for the type of content being edited. For example: Use the weapons navbox ({{tl|Navbox/Weapons}}) on a weapon page instead of the entire items navbox ({{tl|Navbox/Items}}), as using the latter would result in an overwhelming number of links and is less likely to be relevant to the reader.
Sometimes multiple navboxes might be relevant, with only one being the primary or most relevant. An example of this is ammunition. Longbows are very relevant and related to arrows, so it can be useful to have the longbows navbox on the page for an arrow type. [[Metal Arrows]] is an example of this. As the second navbox is secondary, it has been set to default to the collapsed state with the help of the {{para|state}} parameter on the navbox template: <syntaxhighlight lang="wikitext" inline>{{Navbox/Longbows|state=collapsed}}</syntaxhighlight>.
[[Category:Manual of Style]]
5a1e69ff3f11b3b0e7789858c6c080b406db474c
1383
1382
2025-08-27T18:59:19Z
Sharparam
284703
Add section on language
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
== Language ==
Whether you write with an American or British variant of English is not of the utmost importance, just try to stay consistent. Since the game uses American English, try to stick to that.
Above all, strive to maintain proper grammar and punctuation.
== Layout ==
Overall, follow the same layout guidelines as used on Wikipedia ([[wikipedia:Wikipedia:Manual of Style/Layout|Wikipedia:Manual of Style/Layout]]).
This wiki has some common sections that do not appear on Wikipedia though, like <q>Location(s)</q>, <q>Acquisition</q>, and <q>Trivia</q>.
=== Location and acquisition ===
These are important sections and often what readers are interested in when looking up an item for example.
As such, they should appear early, but after the main body content of an article, so usually following the <q>Overview</q> section (if present).
=== Bugs ===
The bugs section is considered part of the appendices, and should appear as the first appendix item following the main content of an article.
=== Trivia ===
The trivia section is considered part of the appendices, and should appear after [[#Bugs|Bugs]].
=== Other sections ===
Sometimes it can be useful to divide an article into more unique sections, like how location articles will have sections listing items, enemies, bosses, and NPCs.
Use your best judgment for where these should be placed, as long as they come after the <q>Overview</q> section.
== Formatting ==
=== Emphasis ===
Due to how Wikitext works, using single quotes to produce italics, bold, or bolded italics (<code><nowiki>''...''</nowiki></code>, <code><nowiki>'''...'''</nowiki></code>, and <code><nowiki>'''''...'''''</nowiki></code>) results in simple typographical styles (with the HTML {{tag|i|open}} and {{tag|b|open}} tags).
When {{em|semantic}} emphasis is what is desired, use the {{tl|Em}} template to produce it (or the {{tag|em}} HTML tag, but the template should be more convenient).
For strong semantic emphasis, use the {{tl|Strong}} template which uses the {{tag|strong}} HTML tag.
=== Date and time ===
In order to have dates and time be consistent across the wiki, there are a few templates to help:
;{{tl|Date}}
:For just a date with no associated time.
;{{tl|Time}}
:For just a time with no associated date.
;{{tl|Datetime}}
:When both date and time are needed.
The templates are currently only able to output dates and times adjusted to UTC (e.g., if you give {{tl|Datetime}} an input of <code>2025-08-27 20:48+02:00</code>, it will render as "{{Datetime|2025-08-27 20:48+02:00}}").
In the future, the templates might be condensed down to a single one that can handle different variants of dates and/or time with support for rendering differerent timezones.
The Wikipedia date/time templates were specifically {{em|not}} copied to this wiki because they do not render into a {{tag|time}} element which makes them worse for accessibility and semantics.
== Infoboxes ==
Infoboxes are very useful to allow readers to quickly see important information in a structured manner that will be consistent between articles. They also help to apply categories to a page.
The following types of articles must have an infobox:
* NPCs ({{tl|Infobox/NPC}})
* Enemies ({{tl|Infobox/Enemy}})
* Bosses ({{tl|Infobox/Boss}})
* Items ({{tl|Infobox/Item}})
** Weapons ({{tl|Infobox/Weapon}})
** Armor ({{tl|Infobox/Armor}})
** Capes ({{tl|Infobox/Cape}})
** Shields ({{tl|Infobox/Shield}})
** Armor set ({{tl|Infobox/Armor set}})
** Amulets ({{tl|Infobox/Amulet}})
* Abilities ({{tl|Infobox/Ability}})
* Passives ({{tl|Infobox/Passive}})
There may be other infoboxes not covered in this manual, the [[:Category:Infobox templates|infobox templates category]] will list all the currently existing infobox templates.
The base {{ml|Infobox}} module should {{strong|never}} be used in an article. It is only used to create more specialized infoboxes.
(Though you can use it to spice up your user page if you want, just don't use it in mainspace content.)
When possible, the image used in the infobox should be an asset extracted from the game. When not possible, take a screenshot in the game and make sure the subject is clearly visible and isolated from unrelated objects with the background as clean as you can manage.
Keep in mind that infobox images will be sized to 300 pixels wide. (Some game assets are smaller than 300 pixels, and then there isn't much you can do, so just allow it to stretch.)
Infoboxes should be put at the top of an article, before the lead text.
== Navboxes ==
Navboxes (or navigation boxes) are put at the end of articles (before any categories) to help readers navigate between related content, like weapons.
See the [[:Category:Navigation templates|navigation templates category]] for currently existing navboxes.
Use the navbox most relevant for the type of content being edited. For example: Use the weapons navbox ({{tl|Navbox/Weapons}}) on a weapon page instead of the entire items navbox ({{tl|Navbox/Items}}), as using the latter would result in an overwhelming number of links and is less likely to be relevant to the reader.
Sometimes multiple navboxes might be relevant, with only one being the primary or most relevant. An example of this is ammunition. Longbows are very relevant and related to arrows, so it can be useful to have the longbows navbox on the page for an arrow type. [[Metal Arrows]] is an example of this. As the second navbox is secondary, it has been set to default to the collapsed state with the help of the {{para|state}} parameter on the navbox template: <syntaxhighlight lang="wikitext" inline>{{Navbox/Longbows|state=collapsed}}</syntaxhighlight>.
[[Category:Manual of Style]]
f5b3fdee2195496df1bd7d013c183c1c81ed7318
1384
1383
2025-08-27T19:08:06Z
Sharparam
284703
/* Date and time */ Add more details on date/time formatting
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
== Language ==
Whether you write with an American or British variant of English is not of the utmost importance, just try to stay consistent. Since the game uses American English, try to stick to that.
Above all, strive to maintain proper grammar and punctuation.
== Layout ==
Overall, follow the same layout guidelines as used on Wikipedia ([[wikipedia:Wikipedia:Manual of Style/Layout|Wikipedia:Manual of Style/Layout]]).
This wiki has some common sections that do not appear on Wikipedia though, like <q>Location(s)</q>, <q>Acquisition</q>, and <q>Trivia</q>.
=== Location and acquisition ===
These are important sections and often what readers are interested in when looking up an item for example.
As such, they should appear early, but after the main body content of an article, so usually following the <q>Overview</q> section (if present).
=== Bugs ===
The bugs section is considered part of the appendices, and should appear as the first appendix item following the main content of an article.
=== Trivia ===
The trivia section is considered part of the appendices, and should appear after [[#Bugs|Bugs]].
=== Other sections ===
Sometimes it can be useful to divide an article into more unique sections, like how location articles will have sections listing items, enemies, bosses, and NPCs.
Use your best judgment for where these should be placed, as long as they come after the <q>Overview</q> section.
== Formatting ==
=== Emphasis ===
Due to how Wikitext works, using single quotes to produce italics, bold, or bolded italics (<code><nowiki>''...''</nowiki></code>, <code><nowiki>'''...'''</nowiki></code>, and <code><nowiki>'''''...'''''</nowiki></code>) results in simple typographical styles (with the HTML {{tag|i|open}} and {{tag|b|open}} tags).
When {{em|semantic}} emphasis is what is desired, use the {{tl|Em}} template to produce it (or the {{tag|em}} HTML tag, but the template should be more convenient).
For strong semantic emphasis, use the {{tl|Strong}} template which uses the {{tag|strong}} HTML tag.
=== Date and time ===
In order to have dates and time be consistent across the wiki, use either [[wikipedia:ISO 8601|ISO 8601]] or [[wikipedia:RFC 3339|RFC 3339]] to format them. For readability, it's not necessary to display seconds or the weekday, and offset can be specified with letters instead of numbers (like "UTC" instead of "+00:00").
There are a few templates to help:
;{{tl|Date}}
:For just a date with no associated time.
;{{tl|Time}}
:For just a time with no associated date.
;{{tl|Datetime}}
:When both date and time are needed.
The templates are currently only able to output dates and times adjusted to UTC (e.g., if you give {{tl|Datetime}} an input of <code>2025-08-27 20:48+02:00</code>, it will render as "{{Datetime|2025-08-27 20:48+02:00}}").
In the future, the templates might be condensed down to a single one that can handle different variants of dates and/or time with support for rendering differerent timezones.
The Wikipedia date/time templates were specifically {{em|not}} copied to this wiki because they do not render into a {{tag|time}} element which makes them worse for accessibility and semantics.
== Infoboxes ==
Infoboxes are very useful to allow readers to quickly see important information in a structured manner that will be consistent between articles. They also help to apply categories to a page.
The following types of articles must have an infobox:
* NPCs ({{tl|Infobox/NPC}})
* Enemies ({{tl|Infobox/Enemy}})
* Bosses ({{tl|Infobox/Boss}})
* Items ({{tl|Infobox/Item}})
** Weapons ({{tl|Infobox/Weapon}})
** Armor ({{tl|Infobox/Armor}})
** Capes ({{tl|Infobox/Cape}})
** Shields ({{tl|Infobox/Shield}})
** Armor set ({{tl|Infobox/Armor set}})
** Amulets ({{tl|Infobox/Amulet}})
* Abilities ({{tl|Infobox/Ability}})
* Passives ({{tl|Infobox/Passive}})
There may be other infoboxes not covered in this manual, the [[:Category:Infobox templates|infobox templates category]] will list all the currently existing infobox templates.
The base {{ml|Infobox}} module should {{strong|never}} be used in an article. It is only used to create more specialized infoboxes.
(Though you can use it to spice up your user page if you want, just don't use it in mainspace content.)
When possible, the image used in the infobox should be an asset extracted from the game. When not possible, take a screenshot in the game and make sure the subject is clearly visible and isolated from unrelated objects with the background as clean as you can manage.
Keep in mind that infobox images will be sized to 300 pixels wide. (Some game assets are smaller than 300 pixels, and then there isn't much you can do, so just allow it to stretch.)
Infoboxes should be put at the top of an article, before the lead text.
== Navboxes ==
Navboxes (or navigation boxes) are put at the end of articles (before any categories) to help readers navigate between related content, like weapons.
See the [[:Category:Navigation templates|navigation templates category]] for currently existing navboxes.
Use the navbox most relevant for the type of content being edited. For example: Use the weapons navbox ({{tl|Navbox/Weapons}}) on a weapon page instead of the entire items navbox ({{tl|Navbox/Items}}), as using the latter would result in an overwhelming number of links and is less likely to be relevant to the reader.
Sometimes multiple navboxes might be relevant, with only one being the primary or most relevant. An example of this is ammunition. Longbows are very relevant and related to arrows, so it can be useful to have the longbows navbox on the page for an arrow type. [[Metal Arrows]] is an example of this. As the second navbox is secondary, it has been set to default to the collapsed state with the help of the {{para|state}} parameter on the navbox template: <syntaxhighlight lang="wikitext" inline>{{Navbox/Longbows|state=collapsed}}</syntaxhighlight>.
[[Category:Manual of Style]]
fc4bb4566e1facec577a3150b50ec49fa1bbbfc7
1386
1384
2025-08-27T21:28:49Z
Sharparam
284703
/* Infoboxes */ Put bosses under enemies
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
== Language ==
Whether you write with an American or British variant of English is not of the utmost importance, just try to stay consistent. Since the game uses American English, try to stick to that.
Above all, strive to maintain proper grammar and punctuation.
== Layout ==
Overall, follow the same layout guidelines as used on Wikipedia ([[wikipedia:Wikipedia:Manual of Style/Layout|Wikipedia:Manual of Style/Layout]]).
This wiki has some common sections that do not appear on Wikipedia though, like <q>Location(s)</q>, <q>Acquisition</q>, and <q>Trivia</q>.
=== Location and acquisition ===
These are important sections and often what readers are interested in when looking up an item for example.
As such, they should appear early, but after the main body content of an article, so usually following the <q>Overview</q> section (if present).
=== Bugs ===
The bugs section is considered part of the appendices, and should appear as the first appendix item following the main content of an article.
=== Trivia ===
The trivia section is considered part of the appendices, and should appear after [[#Bugs|Bugs]].
=== Other sections ===
Sometimes it can be useful to divide an article into more unique sections, like how location articles will have sections listing items, enemies, bosses, and NPCs.
Use your best judgment for where these should be placed, as long as they come after the <q>Overview</q> section.
== Formatting ==
=== Emphasis ===
Due to how Wikitext works, using single quotes to produce italics, bold, or bolded italics (<code><nowiki>''...''</nowiki></code>, <code><nowiki>'''...'''</nowiki></code>, and <code><nowiki>'''''...'''''</nowiki></code>) results in simple typographical styles (with the HTML {{tag|i|open}} and {{tag|b|open}} tags).
When {{em|semantic}} emphasis is what is desired, use the {{tl|Em}} template to produce it (or the {{tag|em}} HTML tag, but the template should be more convenient).
For strong semantic emphasis, use the {{tl|Strong}} template which uses the {{tag|strong}} HTML tag.
=== Date and time ===
In order to have dates and time be consistent across the wiki, use either [[wikipedia:ISO 8601|ISO 8601]] or [[wikipedia:RFC 3339|RFC 3339]] to format them. For readability, it's not necessary to display seconds or the weekday, and offset can be specified with letters instead of numbers (like "UTC" instead of "+00:00").
There are a few templates to help:
;{{tl|Date}}
:For just a date with no associated time.
;{{tl|Time}}
:For just a time with no associated date.
;{{tl|Datetime}}
:When both date and time are needed.
The templates are currently only able to output dates and times adjusted to UTC (e.g., if you give {{tl|Datetime}} an input of <code>2025-08-27 20:48+02:00</code>, it will render as "{{Datetime|2025-08-27 20:48+02:00}}").
In the future, the templates might be condensed down to a single one that can handle different variants of dates and/or time with support for rendering differerent timezones.
The Wikipedia date/time templates were specifically {{em|not}} copied to this wiki because they do not render into a {{tag|time}} element which makes them worse for accessibility and semantics.
== Infoboxes ==
Infoboxes are very useful to allow readers to quickly see important information in a structured manner that will be consistent between articles. They also help to apply categories to a page.
The following types of articles must have an infobox:
* NPCs ({{tl|Infobox/NPC}})
* Enemies ({{tl|Infobox/Enemy}})
** Bosses ({{tl|Infobox/Boss}})
* Items ({{tl|Infobox/Item}})
** Weapons ({{tl|Infobox/Weapon}})
** Armor ({{tl|Infobox/Armor}})
** Capes ({{tl|Infobox/Cape}})
** Shields ({{tl|Infobox/Shield}})
** Armor set ({{tl|Infobox/Armor set}})
** Amulets ({{tl|Infobox/Amulet}})
* Abilities ({{tl|Infobox/Ability}})
* Passives ({{tl|Infobox/Passive}})
There may be other infoboxes not covered in this manual, the [[:Category:Infobox templates|infobox templates category]] will list all the currently existing infobox templates.
The base {{ml|Infobox}} module should {{strong|never}} be used in an article. It is only used to create more specialized infoboxes.
(Though you can use it to spice up your user page if you want, just don't use it in mainspace content.)
When possible, the image used in the infobox should be an asset extracted from the game. When not possible, take a screenshot in the game and make sure the subject is clearly visible and isolated from unrelated objects with the background as clean as you can manage.
Keep in mind that infobox images will be sized to 300 pixels wide. (Some game assets are smaller than 300 pixels, and then there isn't much you can do, so just allow it to stretch.)
Infoboxes should be put at the top of an article, before the lead text.
== Navboxes ==
Navboxes (or navigation boxes) are put at the end of articles (before any categories) to help readers navigate between related content, like weapons.
See the [[:Category:Navigation templates|navigation templates category]] for currently existing navboxes.
Use the navbox most relevant for the type of content being edited. For example: Use the weapons navbox ({{tl|Navbox/Weapons}}) on a weapon page instead of the entire items navbox ({{tl|Navbox/Items}}), as using the latter would result in an overwhelming number of links and is less likely to be relevant to the reader.
Sometimes multiple navboxes might be relevant, with only one being the primary or most relevant. An example of this is ammunition. Longbows are very relevant and related to arrows, so it can be useful to have the longbows navbox on the page for an arrow type. [[Metal Arrows]] is an example of this. As the second navbox is secondary, it has been set to default to the collapsed state with the help of the {{para|state}} parameter on the navbox template: <syntaxhighlight lang="wikitext" inline>{{Navbox/Longbows|state=collapsed}}</syntaxhighlight>.
[[Category:Manual of Style]]
c96fc7923c8afa02b611d0b8d734b16df5e61dab
1387
1386
2025-08-27T21:49:13Z
Sharparam
284703
Add section on references and notes
wikitext
text/x-wiki
This '''Manual of Style''' ('''MoS''' or '''MOS''') is the [[wikipedia:Style manual|style manual]] for the {{BFF}} wiki.
Some of it is adapted from other wikis like [https://en.wikipedia.org Wikipedia].
This will be a living document and likely change over time. If there's ever anything in the article that feels unclear, confusing, or even contradicts itself, please use the [[Meta talk:Manual of Style|talk page]] or contact wiki administrators to have it clarified.
== Language ==
Whether you write with an American or British variant of English is not of the utmost importance, just try to stay consistent. Since the game uses American English, try to stick to that.
Above all, strive to maintain proper grammar and punctuation.
== Layout ==
Overall, follow the same layout guidelines as used on Wikipedia ([[wikipedia:Wikipedia:Manual of Style/Layout|Wikipedia:Manual of Style/Layout]]).
This wiki has some common sections that do not appear on Wikipedia though, like <q>Location(s)</q>, <q>Acquisition</q>, and <q>Trivia</q>.
=== Location and acquisition ===
These are important sections and often what readers are interested in when looking up an item for example.
As such, they should appear early, but after the main body content of an article, so usually following the <q>Overview</q> section (if present).
=== Bugs ===
The bugs section is considered part of the appendices, and should appear as the first appendix item following the main content of an article.
=== Trivia ===
The trivia section is considered part of the appendices, and should appear after [[#Bugs|Bugs]].
=== Other sections ===
Sometimes it can be useful to divide an article into more unique sections, like how location articles will have sections listing items, enemies, bosses, and NPCs.
Use your best judgment for where these should be placed, as long as they come after the <q>Overview</q> section.
== Formatting ==
=== Emphasis ===
Due to how Wikitext works, using single quotes to produce italics, bold, or bolded italics (<code><nowiki>''...''</nowiki></code>, <code><nowiki>'''...'''</nowiki></code>, and <code><nowiki>'''''...'''''</nowiki></code>) results in simple typographical styles (with the HTML {{tag|i|open}} and {{tag|b|open}} tags).
When {{em|semantic}} emphasis is what is desired, use the {{tl|Em}} template to produce it (or the {{tag|em}} HTML tag, but the template should be more convenient).
For strong semantic emphasis, use the {{tl|Strong}} template which uses the {{tag|strong}} HTML tag.
=== Date and time ===
In order to have dates and time be consistent across the wiki, use either [[wikipedia:ISO 8601|ISO 8601]] or [[wikipedia:RFC 3339|RFC 3339]] to format them. For readability, it's not necessary to display seconds or the weekday, and offset can be specified with letters instead of numbers (like "UTC" instead of "+00:00").
There are a few templates to help:
;{{tl|Date}}
:For just a date with no associated time.
;{{tl|Time}}
:For just a time with no associated date.
;{{tl|Datetime}}
:When both date and time are needed.
The templates are currently only able to output dates and times adjusted to UTC (e.g., if you give {{tl|Datetime}} an input of <code>2025-08-27 20:48+02:00</code>, it will render as "{{Datetime|2025-08-27 20:48+02:00}}").
In the future, the templates might be condensed down to a single one that can handle different variants of dates and/or time with support for rendering differerent timezones.
The Wikipedia date/time templates were specifically {{em|not}} copied to this wiki because they do not render into a {{tag|time}} element which makes them worse for accessibility and semantics.
== Infoboxes ==
Infoboxes are very useful to allow readers to quickly see important information in a structured manner that will be consistent between articles. They also help to apply categories to a page.
The following types of articles must have an infobox:
* NPCs ({{tl|Infobox/NPC}})
* Enemies ({{tl|Infobox/Enemy}})
** Bosses ({{tl|Infobox/Boss}})
* Items ({{tl|Infobox/Item}})
** Weapons ({{tl|Infobox/Weapon}})
** Armor ({{tl|Infobox/Armor}})
** Capes ({{tl|Infobox/Cape}})
** Shields ({{tl|Infobox/Shield}})
** Armor set ({{tl|Infobox/Armor set}})
** Amulets ({{tl|Infobox/Amulet}})
* Abilities ({{tl|Infobox/Ability}})
* Passives ({{tl|Infobox/Passive}})
There may be other infoboxes not covered in this manual, the [[:Category:Infobox templates|infobox templates category]] will list all the currently existing infobox templates.
The base {{ml|Infobox}} module should {{strong|never}} be used in an article. It is only used to create more specialized infoboxes.
(Though you can use it to spice up your user page if you want, just don't use it in mainspace content.)
When possible, the image used in the infobox should be an asset extracted from the game. When not possible, take a screenshot in the game and make sure the subject is clearly visible and isolated from unrelated objects with the background as clean as you can manage.
Keep in mind that infobox images will be sized to 300 pixels wide. (Some game assets are smaller than 300 pixels, and then there isn't much you can do, so just allow it to stretch.)
Infoboxes should be put at the top of an article, before the lead text.
== Navboxes ==
Navboxes (or navigation boxes) are put at the end of articles (before any categories) to help readers navigate between related content, like weapons.
See the [[:Category:Navigation templates|navigation templates category]] for currently existing navboxes.
Use the navbox most relevant for the type of content being edited. For example: Use the weapons navbox ({{tl|Navbox/Weapons}}) on a weapon page instead of the entire items navbox ({{tl|Navbox/Items}}), as using the latter would result in an overwhelming number of links and is less likely to be relevant to the reader.
Sometimes multiple navboxes might be relevant, with only one being the primary or most relevant. An example of this is ammunition. Longbows are very relevant and related to arrows, so it can be useful to have the longbows navbox on the page for an arrow type. [[Metal Arrows]] is an example of this. As the second navbox is secondary, it has been set to default to the collapsed state with the help of the {{para|state}} parameter on the navbox template: <syntaxhighlight lang="wikitext" inline>{{Navbox/Longbows|state=collapsed}}</syntaxhighlight>.
== References and notes ==
For references, use the {{tl|Ref}}{{note|Works more like the Wikipedia [[wikipedia:Template:Refn|Template:Refn]] template rather than [[wikipedia:Template:Ref|Template:Ref]]}} template or {{tag|ref}} tag. For notes it might be preferable to use the {{tl|Note}}{{note|Works more like the Wikipedia [[wikipedia:Template:Efn|Template:Efn]] template rather than [[wikipedia:Template:Note|Template:Note]]}} template to ensure the proper lettering is used.
<syntaxhighlight lang="wikitext">
Sometimes text might need notes, things that aren't important enough to add in the text but still interesting.{{note|Usually at the end of a sentence but could also go directly after a word}}
</syntaxhighlight>
If you've used references and/or notes in an article, make sure to put the {{tl|Reflist}} or {{tl|Notelist}} under an appropriate section at the end of the article.
<syntaxhighlight lang="wikitext">
== References ==
{{Reflist}}
</syntaxhighlight>
<syntaxhighlight lang="wikitext">
== Notes ==
{{Notelist}}
</syntaxhighlight>
== Notes ==
{{Notelist}}
[[Category:Manual of Style]]
765a51a9d69cd9a48d761ba41aa9e357306fa18a
Template:Link icon
10
93
1385
115
2025-08-27T21:26:17Z
Sharparam
284703
Make template more flexible
wikitext
text/x-wiki
<includeonly>{{#vardefine:target|{{{1|}}}<!-- end vd -->}}<!--
-->{{#vardefine:display|{{#if:{{{2|}}}|{{{2}}}|{{{1}}}<!-- end if -->}}<!-- end vd -->}}<!--
-->{{#vardefine:type|{{{type|Icon}}}}}<!--
-->{{#vardefine:file|{{#or:{{{file|}}}|{{{icon|}}}|{{{i|}}}|{{#var:target}}_({{#var:type}}).png}}}}<!--
-->{{#vardefine:iconSize|1.2em}}<!--
-->{{#vardefine:lineHeight|1lh}}<!--
-->{{#vardefine:fileExists|{{filepath:{{#var:file}}}}}}<!--
-->{{#ifeq: {{{2|}}} | notext <!-- start if notext
-->|<span class="link-icon notext" style="--link-icon-size: {{#var:iconSize}}; --link-icon-line-height: {{#var:lineHeight}};"><!-- start notext icon element
-->{{#if: {{#var:fileExists}} <!-- start icon if
-->| <span class="regular">[[File:{{#var:file}}|link={{#var:target}}|alt=]]</span><!-- end regular icon
-->| <span class="fallback">[[File:{{#var:file}}|?]]</span><!-- end fallback icon (?)
-->}}<!-- end icon if
--></span><!-- end notext icon
-->|<span class="link-icon" style="--link-icon-size: {{#var:iconSize}}; --link-icon-line-height: {{#var:lineHeight}};"><!-- start icon + text element
-->{{#if: {{#var:fileExists}} <!-- start icon if
-->| <span class="regular">[[File:{{#var:file}}|link={{#var:target}}|alt=]]</span><!-- end regular icon
-->| <span class="fallback">[[File:{{#var:file}}|?]]</span><!-- end fallback icon (?)
-->}} <!-- end icon if
--><span class="display-text">[[{{#var:target}}|{{#var:display}}]]</span><!-- end display text
--></span> <!-- end icon + text element
-->}}<!-- end if notext
--></includeonly><noinclude>{{Documentation}}[[Category:Formatting templates]]</noinclude>
230ff98716418fda1b91a4bef631fd4d3b59e9d4
Template:Reflist
10
613
1388
964
2025-08-27T21:52:48Z
Sharparam
284703
Add "From Wikipedia" hatnote
wikitext
text/x-wiki
<noinclude>{{From Wikipedia|Template:Reflist}}</noinclude>
<templatestyles src="Reflist/styles.css" /><div class="reflist<!--
-->{{#if:{{{1|}}}{{{colwidth|}}}| reflist-columns references-column-width}} {{#switch:{{{liststyle|{{{group|}}}}}}
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = reflist-{{{liststyle|{{{group}}}}}}
}}" <!-- End class, start style -->{{#if:{{{1|}}}
| {{#iferror:{{#ifexpr: {{{1|1}}} > 1 }} |style="column-width: {{{1}}};"}}
| {{#if: {{{colwidth|}}}|style="column-width: {{{colwidth}}};"}}
}}>
{{#tag:references|{{{refs|}}}|group={{{group|}}}|responsive={{#if:{{{1|}}}{{{colwidth|}}}|0|1}}}}</div>{{#invoke:Check for unknown parameters|check|unknown={{main other|[[Category:Pages using reflist with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Reflist]] with unknown parameter "_VALUE_"|ignoreblank=y| 1 | colwidth | group | liststyle | refs }}<noinclude>
{{Documentation}}</noinclude>
cc488133007cdd7b115041428db504520c79b5fa
Template:Reflist/doc
10
870
1389
2025-08-27T21:53:30Z
Sharparam
284703
Created page with "== See also == * {{tl|Notelist}} <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== See also ==
* {{tl|Notelist}}
<noinclude>[[Category:Template documentation]]</noinclude>
817edb987852c4e815df8f37224ac7a4a3803a65
Template:Notelist
10
612
1390
962
2025-08-27T21:54:06Z
Sharparam
284703
Add "From Wikipedia" hatnote
wikitext
text/x-wiki
<noinclude>{{From Wikipedia|Template:Notelist}}</noinclude>
{{safesubst<noinclude />:Reflist|{{{1|{{{colwidth|}}}}}}|refs={{{refs|{{{notes|}}}}}}|group={{safesubst<noinclude />:#switch:{{{group|}}}
| note
| upper-alpha
| upper-roman
| lower-alpha
| lower-greek
| lower-roman = {{{group|}}}
| #default = lower-alpha
}}}}{{safesubst<noinclude />:#invoke:Check for unknown parameters|check|unknown={{Main other|[[Category:Pages using notelist with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Notelist]] with unknown parameter "_VALUE_"|ignoreblank=y| 1 | colwidth | group | notes | refs }}<noinclude>
{{Documentation}}</noinclude>
0af30996296b737c6ca255e4040297f50dd6946f
Template:Notelist/doc
10
871
1391
2025-08-27T21:54:30Z
Sharparam
284703
Created page with "== See also == * {{tl|Reflist}} <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
== See also ==
* {{tl|Reflist}}
<noinclude>[[Category:Template documentation]]</noinclude>
d3a0215a15adc85cdb42fbded8ec28b067119585
Plagued
0
872
1392
2025-09-05T21:13:01Z
Sharparam
284703
Created page with "{{Infobox/Enemy | image = Plagued (enemy).png }} '''Plagued''' is an enemy that appears in the [[Monastery]] location in {{BFF}}. {{Navbox/Enemies}}"
wikitext
text/x-wiki
{{Infobox/Enemy
| image = Plagued (enemy).png
}}
'''Plagued''' is an enemy that appears in the [[Monastery]] location in {{BFF}}.
{{Navbox/Enemies}}
4a165eb28c85124eb2c8fef58807ad6ddc23d3d5
File:Plagued (enemy).png
6
873
1393
2025-09-05T21:13:28Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
File:Konrad the Traitor.png
6
874
1394
2025-09-05T21:13:57Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Mrgud
0
875
1395
2025-09-05T21:37:19Z
Sharparam
284703
Created page with "{{Infobox/Enemy | image = Mrgud (enemy).png }} '''Mrgud''' is an enemy in {{BFF}}. {{Navbox/Enemies}}"
wikitext
text/x-wiki
{{Infobox/Enemy
| image = Mrgud (enemy).png
}}
'''Mrgud''' is an enemy in {{BFF}}.
{{Navbox/Enemies}}
643454a9c803b899b1b971828c544b8f7690aac6
File:Mrgud (enemy).png
6
876
1396
2025-09-05T21:37:32Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Mysterious Woman
0
877
1397
2025-09-05T21:54:44Z
Sharparam
284703
Created page with "{{Infobox/NPC | image = Mysterious Woman (NPC).png }} '''{{PAGENAME}}''' is an [[NPCs|NPC]] in {{BFF}}. == Location == Located in [[Blok 6147]]. == Quotes == === First encounter === {{Quote |I know what you are… But – how can there be anything interesting about a being that never transforms? Hm hm hm… So… What do you think of the city? Quite a few nutcases eh? Stealing always has deep roots among the poor. The children steal, and fathers and mothers too!..."
wikitext
text/x-wiki
{{Infobox/NPC
| image = Mysterious Woman (NPC).png
}}
'''{{PAGENAME}}''' is an [[NPCs|NPC]] in {{BFF}}.
== Location ==
Located in [[Blok 6147]].
== Quotes ==
=== First encounter ===
{{Quote
|I know what you are… But – how can there be anything interesting about a being that never transforms? Hm hm hm…
So… What do you think of the city? Quite a few nutcases eh?
Stealing always has deep roots among the poor. The children steal, and fathers and mothers too! Back when I was on duty in the rough quarters, I would often be robbed of whatever I happened to be carrying.
My cloak, my gloves, even my tools… what do they even do with such things? I was performing a surgery on one of the afflicted once, with his family standing there.
I'm about to give him a sip of the [[Asylum Brew|asylum brew]] to ease the pain, and when I turn back – it's gone! The little ones, smiling at me with their tiny teeth… He he he…
Agh… Probably addicted to it… Kleptomania. Another condition that needs curing…
Say – that vessel of yours? Now that's something I'd tinker with… How much would you sell it for?
They say there's no genius without a touch of madness… What about those where madness is in abundance? Ha ha ha!
Ahhh… *hums happily*
}}
=== After first encounter ===
{{Quote|Ahhh… *hums happily*}}
{{Navbox/NPCs}}
7f7e634bf9fdb130dcd499953d2907f97f7a18d9
1399
1397
2025-09-05T22:05:36Z
Sharparam
284703
/* Location */ Add coordinates
wikitext
text/x-wiki
{{Infobox/NPC
| image = Mysterious Woman (NPC).png
}}
'''{{PAGENAME}}''' is an [[NPCs|NPC]] in {{BFF}}.
== Location ==
{{coords|-16812.77|-10253.53|2049.22}}
Located in [[Blok 6147]].
== Quotes ==
=== First encounter ===
{{Quote
|I know what you are… But – how can there be anything interesting about a being that never transforms? Hm hm hm…
So… What do you think of the city? Quite a few nutcases eh?
Stealing always has deep roots among the poor. The children steal, and fathers and mothers too! Back when I was on duty in the rough quarters, I would often be robbed of whatever I happened to be carrying.
My cloak, my gloves, even my tools… what do they even do with such things? I was performing a surgery on one of the afflicted once, with his family standing there.
I'm about to give him a sip of the [[Asylum Brew|asylum brew]] to ease the pain, and when I turn back – it's gone! The little ones, smiling at me with their tiny teeth… He he he…
Agh… Probably addicted to it… Kleptomania. Another condition that needs curing…
Say – that vessel of yours? Now that's something I'd tinker with… How much would you sell it for?
They say there's no genius without a touch of madness… What about those where madness is in abundance? Ha ha ha!
Ahhh… *hums happily*
}}
=== After first encounter ===
{{Quote|Ahhh… *hums happily*}}
{{Navbox/NPCs}}
d3e154aa9bceae43c67269d0dabf71eadba4d303
File:Mysterious Woman (NPC).png
6
878
1398
2025-09-05T21:56:55Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Royal Division Captain Yulia
0
404
1400
570
2025-09-05T22:12:52Z
Sharparam
284703
Add quotes
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Royal Division Captain Yulia & Vermillion Mirage}}
{{Infobox/NPC
| image = Royal Division Captain Yulia.png
}}
{{stub}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Quotes ==
=== First encounter ===
{{Quote
|This crusade is not only about the city… [[Yaroslav]] is to be apprehended. As long as his example can inspire others, there can be no peace.
I hope you don't judge what you see. We both know justice exists only between those equal in strength. For as it stands, the strong do what they wish, and the weak suffer what they must.
I will confide in you a recent detail. There is a traitor within our higher ranks – I can tolerate many things… but betrayal…
I'll speak frankly with you… This population is lost. The corruption spreads from the [[anomaly]], and even our soldiers are affected… As for the citizens, they were strange to begin with… but many are now completely off the handle. So… I ask of you kindly… Do your part, and I'll see to it that we all return as victors.
This crusade has gone on for too long, yet… it seems as i we have only arrived here.
I miss the wind… The cold air, weaving its way around you as you take in the horizon.
To guide by authority, to graft tradition onto peace, to bestow mercy upon the conquered… to wage war until the proud kneel.
I do not merely rely on you – I trust in you. Don't let me down.
[[The Serdar]] occupation of the gate is only a part of the problem. We also have to deal with the corruption from beyond…
Farewell.
}}
=== After first encounter ===
{{Quote|Farewell.}}
{{Navbox/NPCs}}
90533fb05e4c12a2da999195cc5b65fabc8a25b7
1401
1400
2025-09-05T22:14:46Z
Sharparam
284703
Update file name
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Royal Division Captain Yulia & Vermillion Mirage}}
{{Infobox/NPC
| image = Royal Division Captain Yulia (NPC).png
}}
{{stub}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Quotes ==
=== First encounter ===
{{Quote
|This crusade is not only about the city… [[Yaroslav]] is to be apprehended. As long as his example can inspire others, there can be no peace.
I hope you don't judge what you see. We both know justice exists only between those equal in strength. For as it stands, the strong do what they wish, and the weak suffer what they must.
I will confide in you a recent detail. There is a traitor within our higher ranks – I can tolerate many things… but betrayal…
I'll speak frankly with you… This population is lost. The corruption spreads from the [[anomaly]], and even our soldiers are affected… As for the citizens, they were strange to begin with… but many are now completely off the handle. So… I ask of you kindly… Do your part, and I'll see to it that we all return as victors.
This crusade has gone on for too long, yet… it seems as i we have only arrived here.
I miss the wind… The cold air, weaving its way around you as you take in the horizon.
To guide by authority, to graft tradition onto peace, to bestow mercy upon the conquered… to wage war until the proud kneel.
I do not merely rely on you – I trust in you. Don't let me down.
[[The Serdar]] occupation of the gate is only a part of the problem. We also have to deal with the corruption from beyond…
Farewell.
}}
=== After first encounter ===
{{Quote|Farewell.}}
{{Navbox/NPCs}}
974fe267dcce99e38060a681e8b441903fe7fca0
File:Royal Division Captain Yulia (NPC).png
6
879
1402
2025-09-05T22:14:58Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Royal Division Captain Yulia
0
404
1403
1401
2025-09-05T22:16:42Z
Sharparam
284703
Add location
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Royal Division Captain Yulia & Vermillion Mirage}}
{{Infobox/NPC
| image = Royal Division Captain Yulia (NPC).png
}}
{{stub}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|1070.06|23609.71|3546.89}}
Located in [[Blok 6147]], in a tower surrounded by several [[Dreadguard (NPC)|dreadguards]] (non-hostile NPC variant).
== Quotes ==
=== First encounter ===
{{Quote
|This crusade is not only about the city… [[Yaroslav]] is to be apprehended. As long as his example can inspire others, there can be no peace.
I hope you don't judge what you see. We both know justice exists only between those equal in strength. For as it stands, the strong do what they wish, and the weak suffer what they must.
I will confide in you a recent detail. There is a traitor within our higher ranks – I can tolerate many things… but betrayal…
I'll speak frankly with you… This population is lost. The corruption spreads from the [[anomaly]], and even our soldiers are affected… As for the citizens, they were strange to begin with… but many are now completely off the handle. So… I ask of you kindly… Do your part, and I'll see to it that we all return as victors.
This crusade has gone on for too long, yet… it seems as i we have only arrived here.
I miss the wind… The cold air, weaving its way around you as you take in the horizon.
To guide by authority, to graft tradition onto peace, to bestow mercy upon the conquered… to wage war until the proud kneel.
I do not merely rely on you – I trust in you. Don't let me down.
[[The Serdar]] occupation of the gate is only a part of the problem. We also have to deal with the corruption from beyond…
Farewell.
}}
=== After first encounter ===
{{Quote|Farewell.}}
{{Navbox/NPCs}}
415add9447f36d855407d028a064f1cb7a9bc5b9
Module:Coordinates
828
296
1404
397
2025-09-05T22:18:30Z
Sharparam
284703
Fix tooltip formatting
Scribunto
text/plain
local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$"
local NS_TO_CATEGORISE = {
[0] = true, -- main
[6] = true, -- file
[14] = true -- category
}
local args_util = require('Module:ArgsUtil')
local p = {}
---@param val number
---@param label string
local function coordNode(val, label)
return mw.html.create('span')
:addClass(label)
:wikitext(p.formatCoord(val))
end
---@param val number
---@return string
function p.formatCoord(val)
local sign = val < 0 and '-' or ''
val = math.abs(val)
val = math.floor(val * 100) / 100
local str = tostring(val)
local int = string.match(str, "^%d+")
local dec = string.match(str, "%.(%d-)0*$") or ''
local int_len = #int
local dec_len = #dec
if int_len >= 3 then
return sign .. string.sub(int, 1, 4)
end
if dec_len == 0 then return sign .. int end
return string.format("%s%s.%s", sign, int, string.sub(dec, 1, int_len == 2 and 1 or 2))
end
function p.main(frame)
local args = args_util.merge()
return p._main(args)
end
function p._main(args)
local x = tonumber(args.x or args[1]) or 0
local y = tonumber(args.y or args[2]) or 0
local z = tonumber(args.z or args[3]) or 0
local xdec = string.sub(tostring(math.fmod(x, 1)), 3)
local ydec = string.sub(tostring(math.fmod(y, 1)), 3)
local zdec = string.sub(tostring(math.fmod(z, 1)), 3)
local inaccurate = #xdec ~= 2 or #ydec ~= 2 or #zdec ~= 2
local tooltip = string.format("X: %.2f, Y: %.2f, Z: %.2f", x, y, z)
local elem = mw.html.create('span')
:css('border-bottom', '1px dotted')
:attr('data-x', x)
:attr('data-y', y)
:attr('data-z', z)
:attr('title', tooltip)
:addClass('coordinates')
:addClass('nowrap')
:node(coordNode(x, 'x'))
:wikitext('::')
:node(coordNode(y, 'y'))
:wikitext('::')
:node(coordNode(z, 'z'))
elem = tostring(elem)
local ns = mw.title.getCurrentTitle().namespace
if NS_TO_CATEGORISE[ns] then
if inaccurate then
elem = elem .. '[[Category:Pages with inaccurate coordinates]]'
end
elem = elem .. '[[Category:Pages with coordinates]]'
end
return elem
end
return p
ab0a90c4228892278acd05c8f2df9ebb54fd4375
1405
1404
2025-09-05T22:27:08Z
Sharparam
284703
Fix accuracy check
Scribunto
text/plain
local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$"
local NS_TO_CATEGORISE = {
[0] = true, -- main
[6] = true, -- file
[14] = true -- category
}
local CHECK_PATTERN = "^-?%d+%.%d%d$"
local args_util = require('Module:ArgsUtil')
local p = {}
---@param val number
---@param label string
local function coordNode(val, label)
return mw.html.create('span')
:addClass(label)
:wikitext(p.formatCoord(val))
end
---@param val number
---@return string
function p.formatCoord(val)
local sign = val < 0 and '-' or ''
val = math.abs(val)
val = math.floor(val * 100) / 100
local str = tostring(val)
local int = string.match(str, "^%d+")
local dec = string.match(str, "%.(%d-)0*$") or ''
local int_len = #int
local dec_len = #dec
if int_len >= 3 then
return sign .. string.sub(int, 1, 4)
end
if dec_len == 0 then return sign .. int end
return string.format("%s%s.%s", sign, int, string.sub(dec, 1, int_len == 2 and 1 or 2))
end
function p.main(frame)
local args = args_util.merge()
return p._main(args)
end
function p._main(args)
local x = args.x or args[1] or ""
local y = args.y or args[2] or ""
local z = args.z or args[3] or ""
local accurate_x = string.match(x, CHECK_PATTERN) ~= nil
local accurate_y = string.match(y, CHECK_PATTERN) ~= nil
local accurate_z = string.match(z, CHECK_PATTERN) ~= nil
local accurate = accurate_x or accurate_y or accurate_z
x = tonumber(z) or 0
y = tonumber(z) or 0
z = tonumber(z) or 0
local tooltip = string.format("X: %.2f, Y: %.2f, Z: %.2f", x, y, z)
local elem = mw.html.create('span')
:css('border-bottom', '1px dotted')
:attr('data-x', x)
:attr('data-y', y)
:attr('data-z', z)
:attr('title', tooltip)
:addClass('coordinates')
:addClass('nowrap')
:node(coordNode(x, 'x'))
:wikitext('::')
:node(coordNode(y, 'y'))
:wikitext('::')
:node(coordNode(z, 'z'))
elem = tostring(elem)
local ns = mw.title.getCurrentTitle().namespace
if NS_TO_CATEGORISE[ns] then
if not accurate then
elem = elem .. '[[Category:Pages with inaccurate coordinates]]'
end
elem = elem .. '[[Category:Pages with coordinates]]'
end
return elem
end
return p
2ff934a8e25efa2dcfbbe7d4844d814eaf22c9c0
Homunculus
0
611
1406
975
2025-09-05T22:33:54Z
Sharparam
284703
/* List of homunculi */ Add rain district (sewers) location
wikitext
text/x-wiki
'''Homunculi''' in {{BFF}} exist as objects in the world and [[items]] the player can use.
== Overview ==
The homunculi found in the world are used to teleport between locations, and can also be rested at to recover resources and respawn [[enemies]].
The player can also use the [[Homunculus Mirage]] item to spawn their own homunculus in a location of their choosing (with some restrictions).
== List of homunculi ==
{| class="wikitable"
! [[Locations|Location]] !! Description !! Coordinates
|-
| [[Monastery#Lower|Monastery (Lower)]] || Located on the side of the long roof. In [[New Game Plus]], [[The Handler]] will be standing nearby. || {{coords|22057.55|-89678.87|-15425.86}}
|-
| [[Monastery#Upper|Monastery (Upper)]] || Located just outside the monastery at the top of the area, near [[Konrad the Traitor|Konrad the Traitor's]] boss arena. || {{coords|15413.84|-43467.14|-811.55}}
|-
| [[Blok 6147]] || Located in the center of the circular structures, [[The Handler]] can be found next to it. || {{coords|0|0|1156.54}}
|-
| [[Rain District#Sewers|Rain District (Sewers)]] || Located up the ladder after entering the area from [[Blok 6147]]. || {{coords|-42295.56|-401.90|5081.55}}
|-
| [[Deluge]] || Located at the top of the shaft lined with stairs after entering the area, [[The Handler]] can be found sitting on a ledge nearby. || {{coords|-3185|-7374|5624}}
|-
| [[Ghost Town#Floor 13|Ghost Town (Floor 13)]] || After exiting the elevator, walk down the path and the homunculus will be in an opening on the left. || {{coords|1129|-9050|2199}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || After taking the elevator down from the Floor 13 area, the homunculus will be straight ahead. [[The Handler]] can be found standing to the side of the nearby doorway. || {{coords|1057|-8281|164}}
|-
| [[Machinarium]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead to the left. || {{coords|-2578.36|25970.67|-12004.39}}
|-
| [[Desert]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead below a torch. || {{coords|-9387.86|64791.21|-136368.03}}
|-
| [[Desert Mirage]] || Located straight ahead after entering the teleportation orb. || {{coords|278493.06|-61587.78|-119471.95}}
|-
| [[Anomaly]] || Located on the right after entering the area. [[The Handler]] is standing just ahead, in front of some pillars. || {{coords|47122.91|160919.88|-142106.30}}
|-
| [[Vermillion Fields#Plaza|Vermillion Fields (Plaza)]] || Located in the center of the circular structure, mirroring its location in [[Blok 6147]]. || {{coords|517|-5000|1170}}
|-
| rowspan="3" | [[Vermillion Fields#Temple|Vermillion Fields (Temple)]]{{note|name=temple}}
| Located in a cave after leaving the Plaza area. || {{coords|-26|-5352|2725}}
|-
| After operating a lever in the building on the cliffs, keep going through the area. Eventually you will reach a big circular room and notice a Homunculus in the middle of a bridge. This is the same "Temple" Homunculus as before, but operating the lever has moved it upwards. || {{coords|-58.7|-5351|8264}}
|-
| After operating the second lever near where the second bald knight is after the second homunculus position, the homunculus moves to its final position at the top of the tower. || {{coords|-26.9|-5351|1685}}
|}
== Notes ==
{{notelist|refs=
{{note|name=temple|The homunculus in Vermillion Fields temple moves between the three locations by operating levers.}}
}}
== External links ==
* [[wikipedia:Homunculus|Homunculus on Wikipedia]]
fe28773901e0f42e513362bb666249532e046239
1407
1406
2025-09-05T22:56:22Z
Sharparam
284703
/* List of homunculi */ Add rain district (center) location
wikitext
text/x-wiki
'''Homunculi''' in {{BFF}} exist as objects in the world and [[items]] the player can use.
== Overview ==
The homunculi found in the world are used to teleport between locations, and can also be rested at to recover resources and respawn [[enemies]].
The player can also use the [[Homunculus Mirage]] item to spawn their own homunculus in a location of their choosing (with some restrictions).
== List of homunculi ==
{| class="wikitable"
! [[Locations|Location]] !! Description !! Coordinates
|-
| [[Monastery#Lower|Monastery (Lower)]] || Located on the side of the long roof. In [[New Game Plus]], [[The Handler]] will be standing nearby. || {{coords|22057.55|-89678.87|-15425.86}}
|-
| [[Monastery#Upper|Monastery (Upper)]] || Located just outside the monastery at the top of the area, near [[Konrad the Traitor|Konrad the Traitor's]] boss arena. || {{coords|15413.84|-43467.14|-811.55}}
|-
| [[Blok 6147]] || Located in the center of the circular structures, [[The Handler]] can be found next to it. || {{coords|0|0|1156.54}}
|-
| [[Rain District#Sewers|Rain District (Sewers)]] || Located up the ladder after entering the area from [[Blok 6147]]. || {{coords|-42295.56|-401.90|5081.55}}
|-
| [[Rain District#Center|Rain District (Center)]] || Located at the bottom of the circular area in the center of the rain district, guarded by a large enemy. || {{coords|-43908.60|-9246.53|4632.40}}
|-
| [[Deluge]] || Located at the top of the shaft lined with stairs after entering the area, [[The Handler]] can be found sitting on a ledge nearby. || {{coords|-3185|-7374|5624}}
|-
| [[Ghost Town#Floor 13|Ghost Town (Floor 13)]] || After exiting the elevator, walk down the path and the homunculus will be in an opening on the left. || {{coords|1129|-9050|2199}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || After taking the elevator down from the Floor 13 area, the homunculus will be straight ahead. [[The Handler]] can be found standing to the side of the nearby doorway. || {{coords|1057|-8281|164}}
|-
| [[Machinarium]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead to the left. || {{coords|-2578.36|25970.67|-12004.39}}
|-
| [[Desert]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead below a torch. || {{coords|-9387.86|64791.21|-136368.03}}
|-
| [[Desert Mirage]] || Located straight ahead after entering the teleportation orb. || {{coords|278493.06|-61587.78|-119471.95}}
|-
| [[Anomaly]] || Located on the right after entering the area. [[The Handler]] is standing just ahead, in front of some pillars. || {{coords|47122.91|160919.88|-142106.30}}
|-
| [[Vermillion Fields#Plaza|Vermillion Fields (Plaza)]] || Located in the center of the circular structure, mirroring its location in [[Blok 6147]]. || {{coords|517|-5000|1170}}
|-
| rowspan="3" | [[Vermillion Fields#Temple|Vermillion Fields (Temple)]]{{note|name=temple}}
| Located in a cave after leaving the Plaza area. || {{coords|-26|-5352|2725}}
|-
| After operating a lever in the building on the cliffs, keep going through the area. Eventually you will reach a big circular room and notice a Homunculus in the middle of a bridge. This is the same "Temple" Homunculus as before, but operating the lever has moved it upwards. || {{coords|-58.7|-5351|8264}}
|-
| After operating the second lever near where the second bald knight is after the second homunculus position, the homunculus moves to its final position at the top of the tower. || {{coords|-26.9|-5351|1685}}
|}
== Notes ==
{{notelist|refs=
{{note|name=temple|The homunculus in Vermillion Fields temple moves between the three locations by operating levers.}}
}}
== External links ==
* [[wikipedia:Homunculus|Homunculus on Wikipedia]]
2efb98edd57d3825546ee94ec694118ad28bd346
1408
1407
2025-09-05T22:59:13Z
Sharparam
284703
/* List of homunculi */ Fix coords for deluge
wikitext
text/x-wiki
'''Homunculi''' in {{BFF}} exist as objects in the world and [[items]] the player can use.
== Overview ==
The homunculi found in the world are used to teleport between locations, and can also be rested at to recover resources and respawn [[enemies]].
The player can also use the [[Homunculus Mirage]] item to spawn their own homunculus in a location of their choosing (with some restrictions).
== List of homunculi ==
{| class="wikitable"
! [[Locations|Location]] !! Description !! Coordinates
|-
| [[Monastery#Lower|Monastery (Lower)]] || Located on the side of the long roof. In [[New Game Plus]], [[The Handler]] will be standing nearby. || {{coords|22057.55|-89678.87|-15425.86}}
|-
| [[Monastery#Upper|Monastery (Upper)]] || Located just outside the monastery at the top of the area, near [[Konrad the Traitor|Konrad the Traitor's]] boss arena. || {{coords|15413.84|-43467.14|-811.55}}
|-
| [[Blok 6147]] || Located in the center of the circular structures, [[The Handler]] can be found next to it. || {{coords|0|0|1156.54}}
|-
| [[Rain District#Sewers|Rain District (Sewers)]] || Located up the ladder after entering the area from [[Blok 6147]]. || {{coords|-42295.56|-401.90|5081.55}}
|-
| [[Rain District#Center|Rain District (Center)]] || Located at the bottom of the circular area in the center of the rain district, guarded by a large enemy. || {{coords|-43908.60|-9246.53|4632.40}}
|-
| [[Deluge]] || Located at the top of the shaft lined with stairs after entering the area, [[The Handler]] can be found sitting on a ledge nearby. || {{coords|-31838.95|-7372.77|56246.61}}
|-
| [[Ghost Town#Floor 13|Ghost Town (Floor 13)]] || After exiting the elevator, walk down the path and the homunculus will be in an opening on the left. || {{coords|1129|-9050|2199}}
|-
| [[Ghost Town#Floor 1|Ghost Town (Floor 1)]] || After taking the elevator down from the Floor 13 area, the homunculus will be straight ahead. [[The Handler]] can be found standing to the side of the nearby doorway. || {{coords|1057|-8281|164}}
|-
| [[Machinarium]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead to the left. || {{coords|-2578.36|25970.67|-12004.39}}
|-
| [[Desert]] || Located straight ahead after entering the area, [[The Handler]] can be found just ahead below a torch. || {{coords|-9387.86|64791.21|-136368.03}}
|-
| [[Desert Mirage]] || Located straight ahead after entering the teleportation orb. || {{coords|278493.06|-61587.78|-119471.95}}
|-
| [[Anomaly]] || Located on the right after entering the area. [[The Handler]] is standing just ahead, in front of some pillars. || {{coords|47122.91|160919.88|-142106.30}}
|-
| [[Vermillion Fields#Plaza|Vermillion Fields (Plaza)]] || Located in the center of the circular structure, mirroring its location in [[Blok 6147]]. || {{coords|517|-5000|1170}}
|-
| rowspan="3" | [[Vermillion Fields#Temple|Vermillion Fields (Temple)]]{{note|name=temple}}
| Located in a cave after leaving the Plaza area. || {{coords|-26|-5352|2725}}
|-
| After operating a lever in the building on the cliffs, keep going through the area. Eventually you will reach a big circular room and notice a Homunculus in the middle of a bridge. This is the same "Temple" Homunculus as before, but operating the lever has moved it upwards. || {{coords|-58.7|-5351|8264}}
|-
| After operating the second lever near where the second bald knight is after the second homunculus position, the homunculus moves to its final position at the top of the tower. || {{coords|-26.9|-5351|1685}}
|}
== Notes ==
{{notelist|refs=
{{note|name=temple|The homunculus in Vermillion Fields temple moves between the three locations by operating levers.}}
}}
== External links ==
* [[wikipedia:Homunculus|Homunculus on Wikipedia]]
0e2758460591d215f96693c44a7b739690d877a4
Fisherman
0
541
1409
1360
2025-09-05T23:01:45Z
Sharparam
284703
Update file name
wikitext
text/x-wiki
{{Infobox/Enemy
| image = Fisherman (enemy).png
}}
The '''{{PAGENAME}}''' is an enemy in {{BFF}} that appears in the [[Deluge]] location.
== Drops ==
* [[Diver's Lungs Concoction]]
* [[Fractal Fungus]]
* [[Gingko Leaves]]
* [[Lesser Anomalous Crystal]]
* [[Lesser Restorative Fluid]]
* [[Ring of Burning Desire]]
* [[Sludge]]
* [[Upgrade Splinter]]
{{Navbox/Enemies}}
[[Category:Enemies]]
340515047d434a0a2434986ea2eb1da64a489a07
File:Fisherman (enemy).png
6
880
1410
2025-09-05T23:01:59Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Template:Navbox/Enemies
10
538
1411
837
2025-09-06T00:08:51Z
Sharparam
284703
Update link to dreadguard
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Enemies
| title = [[Enemies]]
| list1 =
* [[Berserking Citizen]]
* [[Citizen]]
* [[Construction Golem]]
* [[Deranged]]
* [[Dreadguard (enemy)|Dreadguard]]
* [[Fisherman]]
* [[Lancer]]
* [[Mechanomad Technomancer]]
* [[Mechanomad Warrior]]
* [[Minotaur]]
* [[Mrgud]]
* [[Osteoclast]]
* [[Plagued]]
* [[Revenant]]
* [[Vermillion Knight]]
* [[Zealot]]
| group2 = [[Bosses]]
| list2 = {{Navbox/Bosses|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
b7758d62938e5072d921bfb6c881b9a69f5dc578
1412
1411
2025-09-06T08:48:37Z
Sharparam
284703
Add abomination
wikitext
text/x-wiki
{{Navbox
| template = Navbox/Enemies
| title = [[Enemies]]
| list1 =
* [[Abomination]]
* [[Berserking Citizen]]
* [[Citizen]]
* [[Construction Golem]]
* [[Deranged]]
* [[Dreadguard (enemy)|Dreadguard]]
* [[Fisherman]]
* [[Lancer]]
* [[Mechanomad Technomancer]]
* [[Mechanomad Warrior]]
* [[Minotaur]]
* [[Mrgud]]
* [[Osteoclast]]
* [[Plagued]]
* [[Revenant]]
* [[Vermillion Knight]]
* [[Zealot]]
| group2 = [[Bosses]]
| list2 = {{Navbox/Bosses|child}}
}}<noinclude>[[Category:Navigation templates]]</noinclude>
2111a990c62fc85b80024f26e04c5aafc8d21f85
Abomination
0
881
1413
2025-09-06T08:51:30Z
Sharparam
284703
Created page with "{{Pages that need coordinates}} {{Infobox/Enemy | image = Abomination (enemy).png }} '''{{PAGENAME}}''' is a large quadrupedal enemy located in [[Rain District#Central|central Rain District]], guarding the [[Homunculus]] there. == Location == Located in [[Rain District#Central|Rain District (Central)]], in front of the [[Homunculus]]. {{Navbox/Enemies}}"
wikitext
text/x-wiki
{{Pages that need coordinates}}
{{Infobox/Enemy
| image = Abomination (enemy).png
}}
'''{{PAGENAME}}''' is a large quadrupedal enemy located in [[Rain District#Central|central Rain District]], guarding the [[Homunculus]] there.
== Location ==
Located in [[Rain District#Central|Rain District (Central)]], in front of the [[Homunculus]].
{{Navbox/Enemies}}
eca98563a99742bf17d0499802df635df0c589db
1427
1413
2025-09-07T17:57:57Z
Sharparam
284703
Fix template call
wikitext
text/x-wiki
{{Needs coordinates}}
{{Infobox/Enemy
| image = Abomination (enemy).png
}}
'''{{PAGENAME}}''' is a large quadrupedal enemy located in [[Rain District#Central|central Rain District]], guarding the [[Homunculus]] there.
== Location ==
Located in [[Rain District#Central|Rain District (Central)]], in front of the [[Homunculus]].
{{Navbox/Enemies}}
6c47197790f0aecd1d5b29e470be36243ed42d87
File:Abomination (enemy).png
6
882
1414
2025-09-06T08:51:43Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Template:Needs coordinates
10
883
1415
2025-09-07T17:28:19Z
Sharparam
284703
Created page with "<includeonly>{{Ambox | color = gold | icon = Cleanup.svg | message = One or more elements on this page needs [[coordinates]] added. You can [{{fullurl:{{FULLPAGENAME}}|action=edit}} edit the page] to add them with the {{tl|Coordinates}} template. | tiny = {{{tiny|}}} | class = {{{class|}}} | date = {{{date|}}} }}<!-- -->{{Main other|{{Yesno|{{{nocat|}}}|no=[[Category:Pages that need coordinates]]}}}}<!-- --></includeonly><!-- --><noinclude>{{Needs coordinates|nocat=ye..."
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = gold
| icon = Cleanup.svg
| message = One or more elements on this page needs [[coordinates]] added. You can [{{fullurl:{{FULLPAGENAME}}|action=edit}} edit the page] to add them with the {{tl|Coordinates}} template.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{Main other|{{Yesno|{{{nocat|}}}|no=[[Category:Pages that need coordinates]]}}}}<!--
--></includeonly><!--
--><noinclude>{{Needs coordinates|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
b983beee1e33d2e1a5676378bfc7042a0a72b6a7
1418
1415
2025-09-07T17:33:27Z
Sharparam
284703
Add what parameter to control text
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = gold
| icon = Cleanup.svg
| message = {{{what|One or more elements on this page}}} needs [[coordinates]] added. You can [{{fullurl:{{FULLPAGENAME}}|action=edit}} edit the page] to add them with the {{tl|Coordinates}} template.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{Main other|{{Yesno|{{{nocat|}}}|no=[[Category:Pages that need coordinates]]}}}}<!--
--></includeonly><!--
--><noinclude>{{Needs coordinates|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
cd5b93a986e9899ea43605ac650a5420850b98b6
MOS
0
884
1416
2025-09-07T17:29:14Z
Sharparam
284703
Redirected page to [[Meta:Manual of Style]]
wikitext
text/x-wiki
#REDIRECT [[Meta:Manual of Style]]
918040eed385668d250445cc55d1b1824e0ed37a
Category:Pages that need coordinates
14
699
1417
1067
2025-09-07T17:31:23Z
Sharparam
284703
Add note on using proper template for categorizing pages
wikitext
text/x-wiki
Pages that are missing coordinates to help players locate them.
Either add coordinates to a "Location" or "Acquisition" section, or to an infobox, as appropriate.
Coordinates can be specified by using the {{tl|Coordinates}} template.
Pages should be added to this category by using the {{tl|Needs coordinates}} template, rather than putting the category on the pages manually.
a8904508baed1e19bc4399a714110d838cf285a5
1420
1417
2025-09-07T17:34:48Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Pages that are missing coordinates to help players locate them.
Either add coordinates to a "Location" or "Acquisition" section, or to an infobox, as appropriate.
Coordinates can be specified by using the {{tl|Coordinates}} template.
Pages should be added to this category by using the {{tl|Needs coordinates}} template, rather than putting the category on the pages manually.
[[Category:Pages in need of improvement]]
111fe578f77b5257e45747743c25fb4cbe8d00b7
1421
1420
2025-09-07T17:38:00Z
Sharparam
284703
Change category
wikitext
text/x-wiki
Pages that are missing coordinates to help players locate them.
Either add coordinates to a "Location" or "Acquisition" section, or to an infobox, as appropriate.
Coordinates can be specified by using the {{tl|Coordinates}} template.
Pages should be added to this category by using the {{tl|Needs coordinates}} template, rather than putting the category on the pages manually.
[[Category:Wiki maintenance]]
061ef35ecfd26a1eab8d9a455ee38633cfe0d8be
Royal Division Captain Yulia & Vermillion Mirage
0
551
1419
863
2025-09-07T17:34:02Z
Sharparam
284703
Use [[Template:Needs coordinates]] instead of manual categorization
wikitext
text/x-wiki
{{Infobox/Boss
| image = Final boss.png
}}
'''{{PAGENAME}}''' is the final [[Bosses|boss]] in {{BFF}}.
== Overview ==
When starting the fight, only the [[Vermillion Mirage]] will be present, including showing only its name in the boss healthbar.
After the mirage takes a certain amount of damage, [[Royal Division Captain Yulia]] will join the fight, updating the name in the boss healthbar to include both of them.
Dying for any reason after Yulia joins the fight causes the player to gain 0.5% [[entropy]]. This is because the act of her joining applies a debuff to the player causing entropy gain on death.
Throughout the fight, they will take turns being the active enemy, with the other one falling back to take a more passive role and using various ranged abilities on the player.
Defeating the boss will immediately trigger the [[Endings|ending]] cutscene.
After getting back to the title screen, the save file can be loaded again which will put the player at the same homunculus, allowing for the boss to be fought again. This makes it the only boss in the game that can be fought multiple times without having to start a new game.
== Location ==
{{Needs coordinates|tiny=yes|what=This section}}
Found at the end of [[Vermillion Fields]]. At the final location of the "Temple" [[Homunculus]], head up the large stairs and the boss arena will be at the top.
{{Navbox/Bosses}}
3e5d852a53a95252f0e47f99dd3b7a828d0e577a
Bleak Faith: Forsaken Wiki/contribute
0
7
1422
1341
2025-09-07T17:41:19Z
Sharparam
284703
Add link to the maintenance category
wikitext
text/x-wiki
{{Main page box/start
| title = Contribute to the wiki
}}
{{SITENAME}} is a collaborative wiki resource that is open for anyone to edit. You don't need special permission beyond [[Special:UserLogin/signup|registering]] an account to edit most pages, and your contributions can grow the wiki and help other players.
; Adding content
:* If you are unsure of what to do or how to create a page, search for a few articles on the same topic and see what they look like. You can always view the source code in a wiki and learn from what others have done.
:* An edit doesn't have to be massive; if you feel you don't want to create whole articles, then just fixing spelling errors and broken links is enough.
:* [[Special:UserLogin/signup|Register]] to edit and track your contributions.
:* Read the [[Meta:Manual of Style|Manual of Style]] for guidance on how to edit the wiki.
:* Check the [[:Category:Wiki_maintenance|wiki maintenance category]] page to get an overview of things that need doing.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
c6826e10822a498bd49ec1145e2951b16d55dbc3
1423
1422
2025-09-07T17:46:15Z
Sharparam
284703
Add more pointers on where to start contributing
wikitext
text/x-wiki
{{Main page box/start
| title = Contribute to the wiki
}}
{{SITENAME}} is a collaborative wiki resource that is open for anyone to edit. You don't need special permission beyond [[Special:UserLogin/signup|registering]] an account to edit most pages, and your contributions can grow the wiki and help other players.
; Adding content
:* If you are unsure of what to do or how to create a page, search for a few articles on the same topic and see what they look like. You can always view the source code in a wiki and learn from what others have done.
:* An edit doesn't have to be massive; if you feel you don't want to create whole articles, then just fixing spelling errors and broken links is enough.
:* [[Special:UserLogin/signup|Register]] to edit and track your contributions.
:* Read the [[Meta:Manual of Style|Manual of Style]] for guidance on how to edit the wiki.
:* Check the [[:Category:Wiki_maintenance|wiki maintenance category]] page to get an overview of things that need doing.
:** Particularly good starting points might be [[Special:WantedFiles|wanted files]] (or [[:Category:Pages with broken file links|pages with broken file links]]) and [[:Category:Pages that need coordinates|pages that need coordinates]].
:** [[:Category:Stubs|Stubs]] can also be a good starting point if you have enough experience to start a page mostly from scratch.
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
cfe43fa8415c0b60a53410c768631ef2c2b37c71
Template:Sfrac/styles.css
10
732
1424
1128
2025-09-07T17:56:44Z
Sharparam
284703
Remove PP template call
sanitized-css
text/css
.sfrac {
white-space: nowrap;
}
.sfrac.tion,
.sfrac .tion {
display: inline-block;
vertical-align: -0.5em;
font-size: 85%;
text-align: center;
}
.sfrac .num {
display: block;
line-height: 1em;
margin: 0.0em 0.1em;
border-bottom: 1px solid;
}
.sfrac .den {
display: block;
line-height: 1em;
margin: 0.1em 0.1em;
}
/* [[Template:Screen reader-only]] is canonical implementation onwiki */
.sr-only {
border: 0;
clip: rect(0, 0, 0, 0); /* removed from CSS */
clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
/* white-space: nowrap; /* already have nowrap above */
}
a0e91db461b3672013e7ed2b0319f6b4d477b2dc
Template:Fraction/styles.css
10
728
1425
1120
2025-09-07T17:57:01Z
Sharparam
284703
Remove PP template call
sanitized-css
text/css
.frac {
white-space: nowrap;
}
.frac .num,
.frac .den {
font-size: 80%;
line-height: 0; /* we want this inline */
vertical-align: super;
}
.frac .den {
vertical-align: sub;
}
/* [[Template:Screen reader-only]] is canonical implementation onwiki */
.sr-only {
border: 0;
clip: rect(0, 0, 0, 0);
clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
/* white-space: nowrap; /* already have nowrap above */
}
d5811eb299db8c77a35b1dd2d75de323ee127834
Template:Hlist/styles.css
10
827
1426
1284
2025-09-07T17:57:24Z
Sharparam
284703
Remove template call
sanitized-css
text/css
/*
* hlist styles are defined in core and Minerva and differ in Minerva. The
* current definitions here (2023-01-01) are sufficient to override Minerva
* without use of the hlist-separated class. The most problematic styles were
* related to margin, padding, and the bullet. Check files listed at
* [[MediaWiki talk:Common.css/to do#hlist-separated]]
*/
/*
* TODO: When the majority of readership supports it (or some beautiful world
* in which grade C support is above the minimum threshold), use :is()
*/
.hlist dl,
.hlist ol,
.hlist ul {
margin: 0;
padding: 0;
}
/* Display list items inline */
.hlist dd,
.hlist dt,
.hlist li {
/*
* don't trust the note that says margin doesn't work with inline
* removing margin: 0 makes dds have margins again
* We also want to reset margin-right in Minerva
*/
margin: 0;
display: inline;
}
/* Display requested top-level lists inline */
.hlist.inline,
.hlist.inline dl,
.hlist.inline ol,
.hlist.inline ul,
/* Display nested lists inline */
.hlist dl dl,
.hlist dl ol,
.hlist dl ul,
.hlist ol dl,
.hlist ol ol,
.hlist ol ul,
.hlist ul dl,
.hlist ul ol,
.hlist ul ul {
display: inline;
}
/* Hide empty list items */
.hlist .mw-empty-li {
display: none;
}
/* TODO: :not() can maybe be used here to remove the later rule. naive test
* seems to work. more testing needed. like so:
*.hlist dt:not(:last-child)::after {
* content: ": ";
*}
*.hlist dd:not(:last-child)::after,
*.hlist li:not(:last-child)::after {
* content: " · ";
* font-weight: bold;
*}
*/
/* Generate interpuncts */
.hlist dt::after {
content: ": ";
}
.hlist dd::after,
.hlist li::after {
content: " · ";
font-weight: bold;
}
.hlist dd:last-child::after,
.hlist dt:last-child::after,
.hlist li:last-child::after {
content: none;
}
/* Add parentheses around nested lists */
.hlist dd dd:first-child::before,
.hlist dd dt:first-child::before,
.hlist dd li:first-child::before,
.hlist dt dd:first-child::before,
.hlist dt dt:first-child::before,
.hlist dt li:first-child::before,
.hlist li dd:first-child::before,
.hlist li dt:first-child::before,
.hlist li li:first-child::before {
content: " (";
font-weight: normal;
}
.hlist dd dd:last-child::after,
.hlist dd dt:last-child::after,
.hlist dd li:last-child::after,
.hlist dt dd:last-child::after,
.hlist dt dt:last-child::after,
.hlist dt li:last-child::after,
.hlist li dd:last-child::after,
.hlist li dt:last-child::after,
.hlist li li:last-child::after {
content: ")";
font-weight: normal;
}
/* Put ordinals in front of ordered list items */
.hlist ol {
counter-reset: listitem;
}
.hlist ol > li {
counter-increment: listitem;
}
.hlist ol > li::before {
content: " " counter(listitem) "\a0";
}
.hlist dd ol > li:first-child::before,
.hlist dt ol > li:first-child::before,
.hlist li ol > li:first-child::before {
content: " (" counter(listitem) "\a0";
}
ad2cb29b8df8d60f4deeb6a5e29187e1003123fe
Inhabitants
0
381
1428
525
2025-09-07T17:58:49Z
Sharparam
284703
Change to needs coords template
wikitext
text/x-wiki
{{stub}}
{{Needs coordinates}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}.
== Overview ==
{{Quote
|The inhabitants, if they can be called that, move through their days in a trance-like manner, their actions governed by the city's oppressive rhythm rather than any discernible purpose. They drift through the shadowy streets, their forms often indistinguishable from the pervasive gloom that surrounds them. Their movements are slow and deliberate, almost mechanical, as if each step is taken in reluctant compliance with an unseen force.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
5266cbc4ddad8e8707d2b5b4cd643e481e2f1f72
Saracen Shield
0
749
1429
1159
2025-09-07T18:00:04Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Saracen Shield.png
| Weight = Heavy
| Abilities = [[Regal Radiance]]
| Mk2_Sharp = 59.5
| Mk2_Blunt = 57.4
| Mk2_Technomancy = 69.3
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== Location ==
{{coords|3760|1142|-1395}}
Found in the [[Desert]]. In the area with Yaroslav's crew, look behind the big statue head to find the shield.
{{Navbox/Shields}}
accf00596a02d4d71fbdbcf43a7cc9ed880910e8
Abilities
0
580
1430
921
2025-09-07T18:04:10Z
Sharparam
284703
Add see also link to passives
wikitext
text/x-wiki
'''Abilities''' are special skills that can be found on some [[weapons]].
== See also ==
* [[Passives]]
{{Navbox/Abilities}}
[[Category:Abilities]]
4a9afbbbbb6640ed8fad199b73590526aad4ff15
Category:Passives
14
885
1431
2025-09-07T18:05:38Z
Sharparam
284703
Created page with "[[Passives]] in {{BFF}}. Add pages to this category by using the {{tl|Infobox/Passive}} template."
wikitext
text/x-wiki
[[Passives]] in {{BFF}}. Add pages to this category by using the {{tl|Infobox/Passive}} template.
34e87bb01c1a0356708b43ee7f6ba248fda0fa61
1434
1431
2025-09-07T18:06:55Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Passives]] in {{BFF}}. Add pages to this category by using the {{tl|Infobox/Passive}} template.
[[Category:Game mechanics]]
f93dc3294b2ea001157045b5b59704e1b259500d
Passives
0
886
1432
2025-09-07T18:06:02Z
Sharparam
284703
Created page with "'''Passives''' are special properties that can be found on various [[equipment]], they provide their bonus at all times and don't need to be activated, unlike [[abilities]]. == See also == * [[Abilities]] [[Category:Passives]]"
wikitext
text/x-wiki
'''Passives''' are special properties that can be found on various [[equipment]], they provide their bonus at all times and don't need to be activated, unlike [[abilities]].
== See also ==
* [[Abilities]]
[[Category:Passives]]
43331e952831989ee9513121b46b294a9fdab4b1
Category:Abilities
14
581
1433
922
2025-09-07T18:06:35Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Abilities]] in {{BFF}}.
[[Category:Game mechanics]]
50df23fadba08e57b44187e5b8ecbaf6a021eb07
Category:Disambiguation templates
14
887
1435
2025-09-07T18:07:25Z
Sharparam
284703
Created blank page
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
Category:Hatnote modules
14
888
1436
2025-09-07T18:07:43Z
Sharparam
284703
Created blank page
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
1451
1436
2025-09-07T18:15:43Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Category:Modules]]
c61dcaccacae29ec6d400192885e53b0ab04ae8b
Category:Disambiguation and redirection hatnote templates
14
889
1437
2025-09-07T18:07:54Z
Sharparam
284703
Created blank page
wikitext
text/x-wiki
da39a3ee5e6b4b0d3255bfef95601890afd80709
Category:Anomalous crystals
14
890
1438
2025-09-07T18:08:25Z
Sharparam
284703
Created page with "[[Anomalous crystals]] in {{BFF}}. [[Category:Items]]"
wikitext
text/x-wiki
[[Anomalous crystals]] in {{BFF}}.
[[Category:Items]]
4de216d6a91d096fba8022567690bb1b72711c3a
Template:Abbr/doc
10
533
1439
827
2025-09-07T18:09:35Z
Sharparam
284703
Add category
wikitext
text/x-wiki
== Examples ==
=== [[Template:Tooltip]] ===
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text|tooltip title}}</syntaxhighlight> → {{Tooltip|text|tooltip title}}
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text "with" quotes|tooltip "with" quotes}}</syntaxhighlight> → {{Tooltip|text "with" quotes|tooltip "with" quotes}}
<noinclude>[[Category:Template documentation]]</noinclude>
2fc823013e38886fd1c58d0df6749119b66a263c
1448
1439
2025-09-07T18:12:40Z
Sharparam
284703
Add category for template
wikitext
text/x-wiki
== Examples ==
=== [[Template:Tooltip]] ===
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text|tooltip title}}</syntaxhighlight> → {{Tooltip|text|tooltip title}}
* <syntaxhighlight lang="wikitext" inline>{{Tooltip|text "with" quotes|tooltip "with" quotes}}</syntaxhighlight> → {{Tooltip|text "with" quotes|tooltip "with" quotes}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
db627ffbedf7c1dc68f985bdca7bd31252f30c52
Template:About/doc
10
735
1440
1132
2025-09-07T18:09:50Z
Sharparam
284703
Add category
wikitext
text/x-wiki
<!--
Categories go where indicated at the bottom of this page, please. -->
{{Tl|About}} is a commonly used [[wikipedia:WP:Hatnote|hatnote template]] for linking the reader to other articles with similar titles or concepts that they may have been seeking instead.
==Usage==
This template should be [[wikipedia:WP:HATNOTEPLACE|placed]] at the top of an article (but following {{Tlx|Short description}}, if present). The template has several formats, including:
*{{Tlx|About}} → {{About}}
*{{Tlx|About|Use1}} → {{About|Use1}}
*{{Tlx|About|<nowiki/>|Use2|Article2}} → {{About||Use2|Article2}}
*{{Tlx|About|<nowiki/>|<nowiki/>||Article (disambiguation)}} → {{About|||Article (disambiguation)}}
*{{Tlx|About|Use1|<nowiki/>|Article2}} → {{About|Use1||Article2}}
*{{Tlx|About|Use1|<nowiki/>|Article2|and|Article3}} → {{About|Use1||Article2|and|Article3}}
*{{Tlx|About|Use1|Use2|Article2}} → {{About|Use1|Use2|Article2}}
*{{Tlx|About|Use1|Use2|Article2|and|Article3}} → {{About|Use1|Use2|Article2|and|Article3}}
*{{Tlx|About|Use1|Use2|Article2|and|Article3|and|Article4|and|Article5}} → {{About|Use1|Use2|Article2|and|Article3|and|Article4|and|Article5}}
*{{Tlx|About|Use1|Use2|Article2|Use3|Article3}} → {{About|Use1|Use2|Article2|Use3|Article3}}
*{{Tlx|About|Use1|Use2|Article2|other uses}} → {{About|Use1|Use2|Article2|other uses}}
The template {{tl|For-multi}} produces the same hatnote, but without the initial ''This template is about''.
=== Styling in italics ===
Please see [[wikipedia:Wikipedia:Hatnote#Hatnotes with italics in the links]] ([[wikipedia:WP:ITHAT]]) for details about how to use italics in hatnotes.
==Parameters==
Alternately, a {{para|section|yes}} parameter can be added to the {{Tl|About}} template for use at the top of a section. When using this parameter, the wording in the template changes to specify that it is being used in a section:
*{{Tlx|About|Use1|<nowiki>section=yes</nowiki>}} → {{About|Use1|section=yes}}
*{{Tlx|About|Use1|<nowiki/>|Article2|<nowiki>section=yes</nowiki>}} → {{About|Use1||Article2|section=yes}}
*{{Tlx|About|Use1|Use2|Article2|<nowiki>section=yes</nowiki>}} → {{About|Use1|Use2|Article2|section=yes}}
*{{Tlx|About|Use1|Use2|Article2|and|Article3|<nowiki>section=yes</nowiki>}} → {{About|Use1|Use2|Article2|and|Article3|section=yes}}
*{{Tlx|About|Use1|Use2|Article2|other uses|<nowiki>section=yes</nowiki>}} → {{About|Use1|Use2|Article2|other uses|section=yes}}
A {{para|text}} option adds text to the end; this should only be used when truly necessary, when the other hatnote templates listed below don't suffice.
The {{para|selfref|yes}} option marks the entire hatnote as a Wikipedia self-reference, causing it to be omitted when the page content is reused outside of Wikipedia (see {{tl|self reference}} and [[wikipedia:MOS:SELFREF]] for more details).
For more options, see section "TemplateData" below.
==TemplateData==
<!--{{TemplateData header}}-->
<!-- Should this mention the existence of "and"? It's something of a can of worms, since it only looks as though it only works in certain combinations of the other page 2/3/4 description fields... -->
<templatedata>
{
"description": "This template is a hatnote in the format \"This page is about … For other uses …\".",
"params": {
"1": {
"label": "Page description",
"type": "string",
"description": "What the page this template is placed on is about (\"This page is about …\")",
"suggested": true
},
"2": {
"label": "Other page 1 description",
"type": "string",
"description": "What the first other page is about. If unused or blank, defaults to \"other uses\".",
"suggested": true
},
"3": {
"label": "Other page 1 title",
"type": "wiki-page-name",
"description": "The title of the first other page. If unused, defaults to \"[page title] (disambiguation)\".",
"suggested": true
},
"4": {
"label": "Other page 2 description",
"type": "string",
"description": "What the second other page is about."
},
"5": {
"label": "Other page 2 title",
"type": "wiki-page-name",
"description": "The title of the second other page. If unused or blank and parameter 4 exists, defaults to \"[page title] (disambiguation)\"."
},
"6": {
"label": "Other page 3 description",
"type": "string",
"description": "What the third other page is about."
},
"7": {
"label": "Other page 3 title",
"type": "wiki-page-name",
"description": "The title of the third other page. If unused or blank and parameter 6 exists, defaults to \"[page title] (disambiguation)\"."
},
"8": {
"label": "Other page 4 description",
"type": "string",
"description": "What the fourth other page is about."
},
"9": {
"label": "Other page 4 title",
"type": "wiki-page-name",
"description": "The title of the fourth other page. If unused or blank and parameter 8 exists, defaults to \"[page title] (disambiguation)\"."
},
"section": {
"type": "string",
"description": "Pass \"yes\" in this parameter to get wording appropriate for use at the top of a section.",
"autovalue": "yes"
},
"text": {
"label": "Custom text",
"type": "string",
"description": "Text to be appended to the end."
}
}
}
</templatedata>
==See also==
* [[wikipedia:Wikipedia:Hatnote]]
<!--{{Hatnote templates}}-->
<!-- To add more other pages, continue with this alternating pattern using increasing numbers, starting with 6 for the next page description. -->
<includeonly>{{Sandbox other||
<!-- Categories go below this line, please; interwikis go to Wikidata, thank you! -->
[[Category:Disambiguation and redirection hatnote templates]]
}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
084e5668a358b8d298f38cdc6d3c975db7098741
Template:Average/doc
10
532
1441
825
2025-09-07T18:10:05Z
Sharparam
284703
Add category
wikitext
text/x-wiki
This template is used to find the average (default mean) of a series of numbers.
==Parameters==
Parameters with a number as the value are the numbers to find the average of.
==Examples==
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|100000000}}</syntaxhighlight> → {{Average|10|20|30|40|100000000}}
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|50|100000000}}</syntaxhighlight> → {{Average|10|20|30|40|50|100000000}}
* <syntaxhighlight lang="wikitext" inline>{{Average|10|20|30|40|50|100000000|round=2}}</syntaxhighlight> → {{Average|10|20|30|40|50|100000000|round=2}}
==See also==
*{{tl|Median}}
<noinclude>[[Category:Template documentation]]</noinclude>
6c6e2c757468014acfc9bb1b053cff9daeccf20c
Template:Coordinates/doc
10
298
1442
396
2025-09-07T18:10:18Z
Sharparam
284703
Add category
wikitext
text/x-wiki
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.5",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.6",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12|y=50|z=-32}}</syntaxhighlight> → {{Coordinates|x=12|y=50|z=-32}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.5|42.5|-4.4}}</syntaxhighlight> → {{Coordinates|16.5|42.5|-4.4}}
* <syntaxhighlight lang="wikitext" inline>{{coords|1.2|3.4|5.6}}</syntaxhighlight> → {{coords|1.2|3.4|5.6}}
* <syntaxhighlight lang="wikitext" inline>{{pos|6.5|4.3|2.1}}</syntaxhighlight> → {{pos|6.5|4.3|2.1}}
<noinclude>[[Category:Template documentation]]</noinclude>
3e8e36f5e300ca38a3ca2e6ff14c9848b28d92df
Template:DamageRange/doc
10
528
1443
817
2025-09-07T18:10:34Z
Sharparam
284703
Add category
wikitext
text/x-wiki
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|10|20}}</syntaxhighlight> → {{DamageRange|10|20}}
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|1|2}}</syntaxhighlight> → {{DamageRange|1|2}}
* <syntaxhighlight lang="wikitext" inline>{{DamageRange|69|75|type=sharp}}</syntaxhighlight> → {{DamageRange|69|75|type=sharp}}
<noinclude>[[Category:Template documentation]]</noinclude>
cc8abbd175ebb12283ae191c68cfb6102179c2ff
Template:Duration/doc
10
789
1444
1228
2025-09-07T18:10:45Z
Sharparam
284703
Add category
wikitext
text/x-wiki
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Duration|3:30}}</syntaxhighlight> → {{Duration|3:30}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|h=1|m=2|s=3}}</syntaxhighlight> → {{Duration|h=1|m=2|s=3}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|3|2|1}}</syntaxhighlight> → {{Duration|3|2|1}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|3:30:00|display=A really long time!}}</syntaxhighlight> → {{Duration|3:30:00|display=A really long time!}}
* <syntaxhighlight lang="wikitext" inline>{{Duration|PT3H30M12S}}</syntaxhighlight> → {{Duration|PT3H30M12S}}
<noinclude>[[Category:Template documentation]]</noinclude>
202a9e40d32b298ce8bf8d682749cbb07096af28
Template:Median/doc
10
706
1445
1079
2025-09-07T18:10:56Z
Sharparam
284703
Add category
wikitext
text/x-wiki
This template is used to find the median of a series of numbers.
{{clear}}
==Parameters==
Parameters with a number as the value are the numbers to find the average of.
==Examples==
*<syntaxhighlight lang="wikitext" inline>{{Median|10|20|30|40|50|1000}}</syntaxhighlight> → {{Median|20|10|30|40|50|1000}}
*<syntaxhighlight lang="wikitext" inline>{{Median|10|20|30|50|1000}}</syntaxhighlight> → {{Median|20|10|30|50|1000}}
*<syntaxhighlight lang="wikitext" inline>{{Median|10.1|20.1|30.1|50.1|1000.1}}</syntaxhighlight> → {{Median|20.1|10.1|30.1|50.1|1000.1}}
==See also==
*{{tl|Average}}
<noinclude>[[Category:Template documentation]]</noinclude>
b212143490662c8a089de324dc4b661ca0a56849
Template:Sandbox other/doc
10
306
1446
400
2025-09-07T18:11:10Z
Sharparam
284703
Add category
wikitext
text/x-wiki
<!-- {{Documentation subpage}} -->
<!-- Categories go at the bottom of this page and interwikis go in Wikidata. -->
<templatedata>
{
"description": {
"en": "This template displays different output on sandbox and documentation pages than other ones."
},
"params": {
"1": {
"label": {
"en": "Sandbox text"
},
"description": {
"en": "Text displayed on sandbox (/sandbox) and documentation (/doc) subpages. Usually this doesn’t contain categories, but it may contain a link to the main template."
},
"type": "content",
"suggested": true
},
"2": {
"label": {
"en": "Normal text"
},
"description": {
"en": "Text displayed everywhere except for sandbox and documentation subpages. Usually this contains categories for the template."
},
"type": "content",
"suggested": true
}
}
}
</templatedata>
<includeonly>{{#ifeq:{{SUBPAGENAME}}|sandbox||
<!-- Categories go here and interwikis go in Wikidata. -->
[[Category:Templates]]
}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
81b917070057eb1ad6e4b9f09f8d69a41a5c9e57
Template:Yesno/doc
10
307
1447
401
2025-09-07T18:11:24Z
Sharparam
284703
Add category
wikitext
text/x-wiki
<!-- {{Documentation subpage}} -->
<!-- PLEASE ADD CATEGORIES AND INTERWIKIS AT THE BOTTOM OF THIS PAGE -->
This template normalises an input to be a yes/no output.
== Usage ==
The template has five possible outputs depending on the default parameter (input if you will).
In its simplest usage, these will all be either "yes" or "" (blank = nothing no characters).
* {{Tlx|Yesno|yes}} → "yes" (also applies to "Yes", "YeS", etc, "Y", "y" and "1")
* {{Tlx|Yesno|no}} → "" (also applies to "No", "NO", "nO", "N", "n" and "0")
* {{Tlx|Yesno}} → ""
* {{Tlx|Yesno|¬}} → ""
* {{Tlx|Yesno|purplemonkeydishwasher}} → "yes" (also applies to any other value not given above)
Each of these can be over-ridden.
* {{Tlx|Yesno|yes|yes{{=}}bacon}} → "{{Yesno|yes|yes=bacon}}" (also applies to "Yes", "YeS", etc, "Y", "y" and "1")
* {{Tlx|Yesno|no|no{{=}}ham}} → "{{Yesno|no|no=ham}}" (also applies to "No", "NO", "nO", "N", "n" and "0")
* {{Tlx|Yesno||blank{{=}}eggs}} → "{{Yesno||blank=eggs}}"
** but {{Tlx|Yesno||no{{=}}ham}} → "{{Yesno||no=ham}}"
** and {{Tlx|Yesno||blank{{=}}eggs|no{{=}}ham}} → "{{Yesno||blank=eggs|no=ham}}"
* {{Tlx|Yesno|¬|¬{{=}}sausage|blank{{=}}eggs|no{{=}}ham}} → "{{Yesno|¬|¬=sausage|blank=eggs|no=ham}}"
** and {{Tlx|Yesno|¬{{=}}sausage|blank{{=}}eggs|no{{=}}ham}} → "{{Yesno|¬=sausage|blank=eggs|no=ham}}"
* {{Tlx|Yesno|purplemonkeydishwasher|def{{=}}cup-of-tea}} → "{{Tlx|Yesno|purplemonkeydishwasher|def{{=}}cup-of-tea}}" (also applies to any other value not given above)
** but {{Tlx|Yesno|purplemonkeydishwasher|yes{{=}}bacon}} → "{{Yesno|purplemonkeydishwasher|yes=bacon}}"
** and {{Tlx|Yesno|purplemonkeydishwasher|def{{=}}cup-of-tea|yes{{=}}bacon}} → "{{Yesno|purplemonkeydishwasher|def=cup-of-tea|yes=bacon}}"
This may be used (apparently perversely) thus:
* {{Tlx|Yesno|yes|yes{{=}}no|no{{=}}yes}} → "{{Yesno|yes|yes=no|no=yes}}"
* {{Tlx|Yesno|no|yes{{=}}no|no{{=}}yes}} → "{{Yesno|no|yes=no|no=yes}}"
This creates a logical inversion.
== TemplateData ==
<!-- {{TemplateData header}} -->
<templatedata>
{
"description": {
"en": "This template normalises an input to be a yes or nil output."
},
"format": "inline",
"params": {
"1": {
"label": {
"en": "Input value"
},
"description": {
"en": "The value to be evaluated."
},
"type": "string",
"required": true
},
"yes": {
"label": {
"en": "Output on yes"
},
"description": {
"en": "Specifies the output of the template when the input value is a case-insensitive forms of 'Yes', 'Y', 'True' or '1'."
},
"type": "string",
"required": false
},
"no": {
"label": {
"en": "Output on no"
},
"description": {
"en": "Specifies the output of the template when the input value is a case-insensitive forms of 'No', 'N', 'False', or '0'."
},
"type": "string",
"required": false
},
"blank": {
"label": {
"en": "Output on blank input"
},
"description": {
"en": "Specifies the output of the template when the input value is defined but is either empty or contains nothing but whitespace character(s)."
},
"type": "string",
"required": false
},
"¬": {
"label": {
"en": "Output on ¬"
},
"description": {
"en": "Specifies the output of the template when the input value is either '¬' or entirely missing (undefined)."
},
"type": "string",
"required": false
},
"def": {
"label": {
"en": "Definite output"
},
"description": {
"en": "Specifies the output of the template when the input value is defined but not a form of 'yes', 'no', '1', '0', '¬' or blank."
},
"type": "string",
"required": false
}
}
}
</templatedata>
== See also ==
* [[Module:Yesno]]
<includeonly>{{Sandbox other||
<!-- CATEGORIES AND INTERWIKIS HERE, THANKS -->
[[Category:Utility templates]]
}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
ac958651ed9ec8ec8a0b3f0a1d3083a2fa331e28
Template:DiscordLink/doc
10
857
1449
1350
2025-09-07T18:13:30Z
Sharparam
284703
Add category for template
wikitext
text/x-wiki
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Type",
"description": "Type of link to produce, leave unspecified or empty for default type.",
"example": "plain",
"type": "line",
"suggestedvalues": [
"default",
"plain"
],
"default": "default"
},
"text": {
"label": "Link text",
"description": "Custom text to show as the link text instead of the default \"Discord\".",
"example": "BFF Discord",
"type": "line",
"default": "Discord"
},
"icon": {
"label": "Show icon",
"description": "Whether to show a Discord icon next to the link.",
"type": "boolean",
"default": "no"
}
},
"description": "Produces a link to the official Bleak Faith: Forsaken Discord server.",
"paramOrder": [
"1",
"text",
"icon"
],
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink}}</syntaxhighlight> → {{DiscordLink}}
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink|icon=yes}}</syntaxhighlight> → {{DiscordLink|icon=yes}}
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink|text=BFF Discord}}</syntaxhighlight> → {{DiscordLink|text=BFF Discord}}
* <syntaxhighlight lang="wikitext" inline>{{DiscordLink|plain}}</syntaxhighlight> → {{DiscordLink|plain}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
5e94bed3c879ca0c034e9fa3bba48ac0d59374d0
Category:Inline templates
14
609
1450
957
2025-09-07T18:15:08Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Templates that can/should be used inline.
[[Category:Templates]]
eb911a83fafb6dcd7d10541fe3bf42da4395f330
Category:Perks
14
763
1452
1179
2025-09-07T18:16:12Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Perks]] in {{BFF}}.
[[Category:Game mechanics]]
8766f0725df74fea3c478872ad19ea3e2732e035
Category:Utility modules
14
315
1453
409
2025-09-07T18:16:35Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Utility Lua modules.
[[Category:Modules]]
2ac38f5cf7fe72c38ba0e1bbfe7c7dd31743b430
Category:Utility templates
14
308
1454
402
2025-09-07T18:16:51Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Utility templates for editing.
[[Category:Templates]]
429393713b4a71585e292b486e4ffcef4c87ce61
Category:Pages with inaccurate coordinates
14
349
1455
462
2025-09-07T18:17:17Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Contains pages using the {{tl|Coordinates}} template or {{ml|Coordinates}} module but passing in one or more coordinates that can be verified to not be completely accurate (i.e. coordinates with fewer than 2 decimals).
[[Category:Wiki maintenance]]
70ee3bdbaac740c9bb377489f9fd4e240f558a11
Category:Modules
14
698
1456
1066
2025-09-07T18:18:13Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Lua modules.
[[Category:Bleak Faith: Forsaken Wiki]]
de766841cc4ddf8c2adbf18a442a28192377cc70
Category:File templates
14
587
1457
928
2025-09-07T18:18:54Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Templates to help work with or categorise files.
[[Category:Templates]]
8e1ff2f0663f9d8800e9f83d2d8c11546b2433d4
Category:Disambiguation templates
14
887
1458
1435
2025-09-07T18:19:43Z
Sharparam
284703
Add category
wikitext
text/x-wiki
[[Category:Templates]]
06eecdec29f6cb215c99cf216d1e3bdc8c30a95e
Category:Manual of Style
14
846
1459
1333
2025-09-07T18:20:13Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Pages that deal with how the wiki should be edited.
[[Category:Bleak Faith: Forsaken Wiki]]
35577961aeea1e2857d5032bdd994c9c3a8a45b0
Category:Module documentation pages
14
316
1460
410
2025-09-07T18:21:51Z
Sharparam
284703
Add category
wikitext
text/x-wiki
Pages that document usage for Lua modules.
[[Category:Modules]]
35a28ebc3e2a045dd778e124a3b89331eceaa6ad
Abomination
0
881
1461
1427
2025-09-07T23:01:43Z
Sharparam
284703
Add coords and fix typo
wikitext
text/x-wiki
{{Infobox/Enemy
| image = Abomination (enemy).png
}}
'''{{PAGENAME}}''' is a large quadrupedal enemy located in [[Rain District#Central|central Rain District]], guarding the [[Homunculus]] there.
== Location ==
{{coords|-43256.48|-9189.85|4654.05}} (approximate)
Located in [[Rain District#Center|Rain District (Center)]], in front of the [[Homunculus]].
{{Navbox/Enemies}}
17a8e1630af5b771bd3959eaaff8671fe1c9c608
Module:Coordinates/doc
828
891
1462
2025-09-07T23:07:54Z
Sharparam
284703
Created page with "== Usage == Do not use the module directly, instead use the {{tl|Coordinates}} template. == Test cases == <!-- * <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|}}</syntaxhighlight> → {{#invoke:Coordinates|main|}} --> === Accurate === * <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1.23|4.56|7.89}}</syntaxhighlight> → {{#invoke:Coordinates|main|1.23|4.56|7.89}} === Inaccurate === * <syntaxhighlight lang="wikitext"..."
wikitext
text/x-wiki
== Usage ==
Do not use the module directly, instead use the {{tl|Coordinates}} template.
== Test cases ==
<!--
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|}}</syntaxhighlight> → {{#invoke:Coordinates|main|}}
-->
=== Accurate ===
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1.23|4.56|7.89}}</syntaxhighlight> → {{#invoke:Coordinates|main|1.23|4.56|7.89}}
=== Inaccurate ===
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1|2|3}}</syntaxhighlight> → {{#invoke:Coordinates|main|1|2|3}}
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1.0|2.0|3.0}}</syntaxhighlight> → {{#invoke:Coordinates|main|1.0|2.0|3.0}}
<includeonly>{{Sandbox other||[[Category:Modules]]}}</includeonly><!--
--><noinclude>[[Category:Module documentation pages]]</noinclude>
7cb6b3be92ebb1fc3e188425e895d53a96683999
1464
1462
2025-09-07T23:14:33Z
Sharparam
284703
Add link to styles
wikitext
text/x-wiki
== Usage ==
Do not use the module directly, instead use the {{tl|Coordinates}} template.
== Styles ==
* [[Module:Coordinates/styles.css]]
== Test cases ==
<!--
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|}}</syntaxhighlight> → {{#invoke:Coordinates|main|}}
-->
=== Accurate ===
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1.23|4.56|7.89}}</syntaxhighlight> → {{#invoke:Coordinates|main|1.23|4.56|7.89}}
=== Inaccurate ===
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1|2|3}}</syntaxhighlight> → {{#invoke:Coordinates|main|1|2|3}}
* <syntaxhighlight lang="wikitext" inline>{{#invoke:Coordinates|main|1.0|2.0|3.0}}</syntaxhighlight> → {{#invoke:Coordinates|main|1.0|2.0|3.0}}
<includeonly>{{Sandbox other||[[Category:Modules]]}}</includeonly><!--
--><noinclude>[[Category:Module documentation pages]]</noinclude>
fd213ce58882a30d859ed97c03e80ca03fa7965e
Module:Coordinates/styles.css
828
892
1463
2025-09-07T23:13:43Z
Sharparam
284703
Created page with ".coordinates { text-decoration: underline dotted; } .coordinates.inaccurate { text-decoration-color: red; text-decoration-style: wavy; }"
sanitized-css
text/css
.coordinates {
text-decoration: underline dotted;
}
.coordinates.inaccurate {
text-decoration-color: red;
text-decoration-style: wavy;
}
db96eb1801a0135aa30f3280e515af2094d423af
Module:Coordinates
828
296
1465
1405
2025-09-07T23:18:39Z
Sharparam
284703
Use stylesheet
Scribunto
text/plain
local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$"
local NS_TO_CATEGORISE = {
[0] = true, -- main
[6] = true, -- file
[14] = true -- category
}
local CHECK_PATTERN = "^-?%d+%.%d%d$"
local args_util = require('Module:ArgsUtil')
local p = {}
---@param val number
---@param label string
local function coordNode(val, label)
return mw.html.create('span')
:addClass(label)
:wikitext(p.formatCoord(val))
end
---@param val number
---@return string
function p.formatCoord(val)
local sign = val < 0 and '-' or ''
val = math.abs(val)
val = math.floor(val * 100) / 100
local str = tostring(val)
local int = string.match(str, "^%d+")
local dec = string.match(str, "%.(%d-)0*$") or ''
local int_len = #int
local dec_len = #dec
if int_len >= 3 then
return sign .. string.sub(int, 1, 4)
end
if dec_len == 0 then return sign .. int end
return string.format("%s%s.%s", sign, int, string.sub(dec, 1, int_len == 2 and 1 or 2))
end
function p.main(frame)
local args = args_util.merge()
return p._main(args)
end
function p._main(args)
local x = args.x or args[1] or ""
local y = args.y or args[2] or ""
local z = args.z or args[3] or ""
local accurate_x = string.match(x, CHECK_PATTERN) ~= nil
local accurate_y = string.match(y, CHECK_PATTERN) ~= nil
local accurate_z = string.match(z, CHECK_PATTERN) ~= nil
local accurate = accurate_x or accurate_y or accurate_z
x = tonumber(z) or 0
y = tonumber(z) or 0
z = tonumber(z) or 0
local tooltip = string.format("X: %.2f, Y: %.2f, Z: %.2f", x, y, z)
local elem = mw.html.create('span')
:attr('data-x', x)
:attr('data-y', y)
:attr('data-z', z)
:attr('title', tooltip)
:addClass('coordinates')
:addClass('nowrap')
:node(coordNode(x, 'x'))
:wikitext('::')
:node(coordNode(y, 'y'))
:wikitext('::')
:node(coordNode(z, 'z'))
if not accurate then
elem = elem:addClass('inaccurate')
end
elem = tostring(elem)
local ns = mw.title.getCurrentTitle().namespace
if NS_TO_CATEGORISE[ns] then
if not accurate then
elem = elem .. '[[Category:Pages with inaccurate coordinates]]'
end
elem = elem .. '[[Category:Pages with coordinates]]'
end
local with_styles = mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Coordinates/styles.css' }
} .. elem
return with_styles
end
return p
593292e1a1dac54b90713ee4b0ef431dbbfa2c72
Template:Coordinates/doc
10
298
1466
1442
2025-09-07T23:22:19Z
Sharparam
284703
Make sure examples use accurate coordinates, add example of inaccurate coords
wikitext
text/x-wiki
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.5",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.6",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12.42|y=50.00|z=-32.70}}</syntaxhighlight> → {{Coordinates|x=12.42|y=50.00|z=-32.70}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.51|42.55|-4.43}}</syntaxhighlight> → {{Coordinates|16.51|42.55|-4.43}}
* <syntaxhighlight lang="wikitext" inline>{{coords|1.23|4.56|7.89}}</syntaxhighlight> → {{coords|1.23|4.56|7.89}}
* <syntaxhighlight lang="wikitext" inline>{{pos|6.51|4.32|2.13}}</syntaxhighlight> → {{pos|6.51|4.32|2.13}}
Supplying inaccurate coordinates (not using two decimals) will produce an error underline to make them easy to spot:
<syntaxhighlight lang="wikitext" inline>{{coords|1|2|3}}</syntaxhighlight> → {{coords|1|2|3}}
<noinclude>[[Category:Template documentation]]</noinclude>
a89bb1bedd24821a52110ebb711f71eccca244ef
Diver's Lungs Concoction
0
893
1467
2025-09-07T23:28:35Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Diver's Lungs Concoction (item).png | type = concoction | Description = Increases maximum lung capacity by {{Duration|s=25|display=25 seconds}} worth of oxygen for {{Duration|s=300|display=300 seconds}}. }} '''{{PAGENAME}}''' is a [[Concoctions|concoction]] in {{BFF}}. It lets the player stay longer underwater by increasing their lung capacity. == Acquisition == Drops from [[Fisherman|fishermen]]. {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Diver's Lungs Concoction (item).png
| type = concoction
| Description = Increases maximum lung capacity by {{Duration|s=25|display=25 seconds}} worth of oxygen for {{Duration|s=300|display=300 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Concoctions|concoction]] in {{BFF}}. It lets the player stay longer underwater by increasing their lung capacity.
== Acquisition ==
Drops from [[Fisherman|fishermen]].
{{Navbox/Consumables}}
144f3fe65f87d139bda8b687ddc4fb8c8504d2bc
File:Diver's Lungs Concoction (item).png
6
894
1468
2025-09-07T23:30:13Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_51
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_51
}}
== Licensing ==
{{License|game}}
a816b0fa3540456c73cc969d2ab7d66a4dd6fc96
Asylum Brew
0
895
1469
2025-09-07T23:33:30Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Asylum Brew (item).png | type = consumable | Description = Reset all of your assigned perks. Usable from inventory. }} '''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}. == Location == {{Needs coordinates|tiny=yes|what=This section}} Found near the beginning of the game in [[New Game Plus|NG+]]. {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Asylum Brew (item).png
| type = consumable
| Description = Reset all of your assigned perks. Usable from inventory.
}}
'''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}.
== Location ==
{{Needs coordinates|tiny=yes|what=This section}}
Found near the beginning of the game in [[New Game Plus|NG+]].
{{Navbox/Consumables}}
caf9c60ae34d33f482c4f29382ae04e416fa872f
File:Asylum Brew (item).png
6
896
1470
2025-09-07T23:34:03Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_37
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_37
}}
== Licensing ==
{{License|game}}
24ecfc87dbf948b55ba33c7b915c6a35e7485d42
Ionization Fluid
0
897
1471
2025-09-07T23:37:12Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Ionization Fluid (item).png | type = fluid | Description = Once the bloodline of the [[Imperium]], the Ionization fluid remains the most essential variable in most [[Technomancy]]. Restores 175 [[Flux]]. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}} used to restore [[flux]]. == See also == * [[Lesser Ionization Fluid]] * [[Greater Ionization Fluid]] {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Ionization Fluid (item).png
| type = fluid
| Description = Once the bloodline of the [[Imperium]], the Ionization fluid remains the most essential variable in most [[Technomancy]]. Restores 175 [[Flux]].
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}} used to restore [[flux]].
== See also ==
* [[Lesser Ionization Fluid]]
* [[Greater Ionization Fluid]]
{{Navbox/Consumables}}
6ee67fb9d6d89ed7111b124b114aef624b14f278
File:Ionization Fluid (item).png
6
898
1472
2025-09-07T23:38:05Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_8
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_8
}}
== Licensing ==
{{License|game}}
3359aa55c3123704b247968effea8c856f0e15f2
Lesser Ionization Fluid
0
899
1473
2025-09-07T23:40:20Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Lesser Ionization Fluid (item).png | type = fluid | Description = Once the bloodline of the [[Imperium]], the Ionization fluid remains the most essential variable in most [[Technomancy]]. Restores 100 [[Flux]]. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}} used to restore [[Flux]]. == See also == * [[Ionization Fluid]] * [[Greater Ionization Fluid]] {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Lesser Ionization Fluid (item).png
| type = fluid
| Description = Once the bloodline of the [[Imperium]], the Ionization fluid remains the most essential variable in most [[Technomancy]]. Restores 100 [[Flux]].
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}} used to restore [[Flux]].
== See also ==
* [[Ionization Fluid]]
* [[Greater Ionization Fluid]]
{{Navbox/Consumables}}
a00def1510294b50f411d6303801b7a5c58bbdf2
File:Lesser Ionization Fluid (item).png
6
900
1474
2025-09-07T23:40:47Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_15
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_15
}}
== Licensing ==
{{License|game}}
e95f0029f64512e2c93aa8579965a15b6f419220
Greater Ionization Fluid
0
901
1475
2025-09-07T23:42:11Z
Sharparam
284703
Created page with "{{Infobox/Item | image = Greater Ionization Fluid (item).png | type = fluid | Description = Once the bloodline of the [[Imperium]], the Ionization fluid remains the most essential variable in most [[Technomancy]]. Restores 175 [[Flux]]. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}} used to restore [[Flux]]. == See also == * [[Lesser Ionization Fluid]] * [[Ionization Fluid]] {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Infobox/Item
| image = Greater Ionization Fluid (item).png
| type = fluid
| Description = Once the bloodline of the [[Imperium]], the Ionization fluid remains the most essential variable in most [[Technomancy]]. Restores 175 [[Flux]].
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}} used to restore [[Flux]].
== See also ==
* [[Lesser Ionization Fluid]]
* [[Ionization Fluid]]
{{Navbox/Consumables}}
67290ee299ee4f517ec4648e6dc1648dd6dcff7a
File:Greater Ionization Fluid (item).png
6
902
1476
2025-09-07T23:42:37Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_3
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_3
}}
== Licensing ==
{{License|game}}
65acf6a2babd2d5f488554363f7633670653542a
Template:Infobox/Shield
10
457
1477
679
2025-09-07T23:47:29Z
Sharparam
284703
Add support for min mark and title fallback
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=shield
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Weight,Passives,Abilities
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{#if:{{{Mk0_Sharp|}}}|{{{Mk0_Sharp}}}%|???}}
|Mk0_Blunt={{#if:{{{Mk0_Blunt|}}}|{{{Mk0_Blunt}}}%|???}}
|Mk0_Technomancy={{#if:{{{Mk0_Technomancy|}}}|{{{Mk0_Technomancy}}}%|???}}
|Mk1_Sharp={{#if:{{{Mk1_Sharp|}}}|{{{Mk1_Sharp}}}%|???}}
|Mk1_Blunt={{#if:{{{Mk1_Blunt|}}}|{{{Mk1_Blunt}}}%|???}}
|Mk1_Technomancy={{#if:{{{Mk1_Technomancy|}}}|{{{Mk1_Technomancy}}}%|???}}
|Mk2_Sharp={{#if:{{{Mk2_Sharp|}}}|{{{Mk2_Sharp}}}%|???}}
|Mk2_Blunt={{#if:{{{Mk2_Blunt|}}}|{{{Mk2_Blunt}}}%|???}}
|Mk2_Technomancy={{#if:{{{Mk2_Technomancy|}}}|{{{Mk2_Technomancy}}}%|???}}
|Mk3_Sharp={{#if:{{{Mk3_Sharp|}}}|{{{Mk3_Sharp}}}%|???}}
|Mk3_Blunt={{#if:{{{Mk3_Blunt|}}}|{{{Mk3_Blunt}}}%|???}}
|Mk3_Technomancy={{#if:{{{Mk3_Technomancy|}}}|{{{Mk3_Technomancy}}}%|???}}
|Mk4_Sharp={{#if:{{{Mk4_Sharp|}}}|{{{Mk4_Sharp}}}%|???}}
|Mk4_Blunt={{#if:{{{Mk4_Blunt|}}}|{{{Mk4_Blunt}}}%|???}}
|Mk4_Technomancy={{#if:{{{Mk4_Technomancy|}}}|{{{Mk4_Technomancy}}}%|???}}
|Mk5_Sharp={{#if:{{{Mk5_Sharp|}}}|{{{Mk5_Sharp}}}%|???}}
|Mk5_Blunt={{#if:{{{Mk5_Blunt|}}}|{{{Mk5_Blunt}}}%|???}}
|Mk5_Technomancy={{#if:{{{Mk5_Technomancy|}}}|{{{Mk5_Technomancy}}}%|???}}
}}{{#if:{{NAMESPACE}}||[[Category:Shields]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
8931d1e93b36fefa8ff5cacb37de1f62f098337b
Flat Shield
0
903
1478
2025-09-07T23:48:07Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Shield | title = {{PAGENAME}} | image = Flat Shield.png | Weight = Heavy | Mk_min = 1 | Mk1_Sharp = 61.7 | Mk1_Blunt = 58.5 | Mk1_Technomancy = 39 }} '''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}. {{Navbox/Shields}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Shield
| title = {{PAGENAME}}
| image = Flat Shield.png
| Weight = Heavy
| Mk_min = 1
| Mk1_Sharp = 61.7
| Mk1_Blunt = 58.5
| Mk1_Technomancy = 39
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
{{Navbox/Shields}}
940a44e19c55c0458ac6add23e0b2691944c7f1f
File:Flat Shield.png
6
904
1479
2025-09-07T23:49:29Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_KiteshieldFlat
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_KiteshieldFlat
}}
== Licensing ==
{{License|game}}
3e580546301203f92f639bfac3e05acb6b3cb182
Template:Needs location
10
905
1480
2025-09-07T23:51:25Z
Sharparam
284703
Created page with "<includeonly>{{Ambox | color = gold | icon = Cleanup.svg | message = {{{what|This page}}} needs a location section added. You can [{{fullurl:{{FULLPAGENAME}}|action=edit}} edit it] to add one. | tiny = {{{tiny|}}} | class = {{{class|}}} | date = {{{date|}}} }}<!-- -->{{Main other|{{Yesno|{{{nocat|}}}|no=[[Category:Pages missing location]]}}}}<!-- --></includeonly><!-- --><noinclude>{{Needs location|nocat=yes}} {{doc|Template:Ambox/doc}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{Ambox
| color = gold
| icon = Cleanup.svg
| message = {{{what|This page}}} needs a location section added. You can [{{fullurl:{{FULLPAGENAME}}|action=edit}} edit it] to add one.
| tiny = {{{tiny|}}}
| class = {{{class|}}}
| date = {{{date|}}}
}}<!--
-->{{Main other|{{Yesno|{{{nocat|}}}|no=[[Category:Pages missing location]]}}}}<!--
--></includeonly><!--
--><noinclude>{{Needs location|nocat=yes}}
{{doc|Template:Ambox/doc}}</noinclude>
562974d484e01f92cfa7c30ccf742dc32a1aaf5e
Category:Pages missing location
14
906
1481
2025-09-07T23:52:39Z
Sharparam
284703
Created page with "Pages in this category are missing location information for where they can be obtained or are located. To put a page in this category, use the {{tl|Needs location}} template. [[Category:Wiki maintenance]]"
wikitext
text/x-wiki
Pages in this category are missing location information for where they can be obtained or are located.
To put a page in this category, use the {{tl|Needs location}} template.
[[Category:Wiki maintenance]]
5eac526e708aab4f90b14769338f0958466bed6f
Kite Shield
0
907
1482
2025-09-07T23:54:13Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Shield | image = Kite Shield.png | Weight = Heavy | Mk_min = 0 | Mk0_Sharp = 51 | Mk0_Blunt = 51 | Mk0_Technomancy = 30 }} '''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}. {{Navbox/Shields}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Shield
| image = Kite Shield.png
| Weight = Heavy
| Mk_min = 0
| Mk0_Sharp = 51
| Mk0_Blunt = 51
| Mk0_Technomancy = 30
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
{{Navbox/Shields}}
c0d3267e89401628212c8046a21053f517afa77e
File:Kite Shield.png
6
908
1483
2025-09-07T23:55:47Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/KiteShieldIcon
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/KiteShieldIcon
}}
== Licensing ==
{{License|game}}
d7a68d97c4061fd014bdfd9b8381fbffc3e7e854
Military Shield
0
909
1484
2025-09-07T23:56:59Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Shield | image = Military Shield.png | Weight = Heavy | Abilities = Shield Bash | Mk_min = 2 | Mk0_Sharp = 66.5 | Mk0_Blunt = 59.5 | Mk0_Technomancy = 52.5 }} '''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}. == See also == * [[Tall Military Shield]] {{Navbox/Shields}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Shield
| image = Military Shield.png
| Weight = Heavy
| Abilities = Shield Bash
| Mk_min = 2
| Mk0_Sharp = 66.5
| Mk0_Blunt = 59.5
| Mk0_Technomancy = 52.5
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== See also ==
* [[Tall Military Shield]]
{{Navbox/Shields}}
2bd0947b343b32db4e42502c0f90481467b96564
1486
1484
2025-09-07T23:58:00Z
Sharparam
284703
Fix stats
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Shield
| image = Military Shield.png
| Weight = Heavy
| Abilities = Shield Bash
| Mk_min = 2
| Mk2_Sharp = 66.5
| Mk2_Blunt = 59.5
| Mk2_Technomancy = 52.5
}}
'''{{PAGENAME}}''' is a [[Shields|shield]] in {{BFF}}.
== See also ==
* [[Tall Military Shield]]
{{Navbox/Shields}}
ea347b44b98dffeb9aeaeed7791d1b25fa21de12
File:Military Shield.png
6
910
1485
2025-09-07T23:57:44Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/icon_militaryshield
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/icon_militaryshield
}}
== Licensing ==
{{License|game}}
06a72fbf6338f7d8b747ffca7ca91e957da3af9c
The Handler
0
345
1487
458
2025-09-08T00:06:11Z
Sharparam
284703
/* Locations */ Add rain district location and fix deluge coords
wikitext
text/x-wiki
{{Infobox/NPC
| image = The Handler Blok 6147.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}} that will let the player upgrade their [[equipment]], embed crystals into it, and manufacture certain [[items]].
== Overview ==
Other than serving as a way to upgrade and manufacture items, she will also give the player some guidance on their next objective.
She will usually appear next to the [[Homunculus]] closest to the entrance of an area.
The Handler's synchronization level can be increased by finding [[Handler Echo|handler echoes]] and bringing them to her. Increasing her level allows for upgrading [[equipment]] to higher levels.
== Appearance ==
She appears to be some sort of robot or cyborg, with light skin, black parts, and silver hair.
== Locations ==
{| class="wikitable"
! scope="col" | Area
! scope="col" | Description
! scope="col" | Coordinates
|-
| [[Monastery]] || Near the first [[Homunculus]] (only in [[New Game Plus]]) || {{coords|23473.78|-85243.22|-15260.61}}
|-
| [[Blok 6147]] || In the center (right next to the [[Homunculus]]) || {{coords|-25.27|442.48|1160.96}}
|-
| [[Rain District]] || In the center area, in front of a wall to the left of the [[Homunculus]] || {{coords|-43084.52|-8483.92|4575.76}}
|-
| [[Deluge]] || Sitting on a ledge near the first [[Homunculus]] || {{coords|-33118.94|-7478.60|56507.07}}
|-
| [[Asylum]] || Standing in front of a pillar near the [[Homunculus]] || {{coords|-4507|6967|9032}}
|-
| [[Upper Blocks]] || Standing in front of some rubble opposite of the [[Homunculus]] || {{coords|4585|1626|2193}}
|-
| [[Machinarium]] || Standing next to a wall just past the first [[Homunculus]] || {{coords|-2125.53|27029.25|-12156.72}}
|-
| [[Desert]] || Standing next to a wall just past the [[Homunculus]] || {{coords|-9576.35|65589.26|-136382.62}}
|-
| [[Anomaly]] || Standing next to a pair of pillars just past the [[Homunculus]] || {{coords|46782.80|162169.12|-141987.55}}
|-
| [[Vermillion Fields]] || Standing next to the [[Homunculus]], mirroring her location in [[Blok 6147]] || {{coords|582|-4995|1178}}
|}
== Quotes ==
=== When approached ===
When approached without any special event dialogue waiting to be triggered, she will pick one of the below greeting phrases at random.
{{Quote|Hello!|audio=The_Handler_Hello.ogg}}
{{Quote|Hello there!|audio=The_Handler_Hello_There.ogg}}
{{Quote|Well hello there!|audio=The_Handler_Well_Hello_There.ogg}}
{{Quote|Back so soon!|audio=The_Handler_Back_So_Soon.ogg}}
{{Quote|Look who came to visit!|audio=The_Handler_Look_Who_Came_To_Visit.ogg}}
=== First encounter ===
{{Quote
|You're finally here. We can now commence the [[recalibration]].
I've updated the locations of the malfunctioning modules in the terminal. Any time you link to a terminal, you should be able to see the modules.
I must advise utmost caution, as I have surveyed the area and it is infested with aggressive mutations.
The radiation leaking out of [[The Anomaly|the anomaly]] is causing a strong disturbance in the casual field. We should leave this place as soon as possible.
The readings are unlike anything I've seen. The data is completely unstable as I am still unable to upload it for decyphering.
Farewell.
| audio = The_Handler_First_Encounter.ogg
}}
=== After first [[recalibration]] ===
{{Quote
|There is one module left to recalibrate. Unfortunately the data leaking from [[The Anomaly|the anomaly]] is still too corrupted to read.
The surveillance net has taken note of ripples with particularly long wavelengths unusually coming into existence. I believe it's a sign of intruders – particularly dangerous ones that are not of our timeline.
I am not sure I understand what exactly is going on here. I suppose we are yet to learn the true definition of something anomalous.
Farewell.
}}
=== After second [[recalibration]] ===
{{Quote
|The [[recalibration]] was successful, the transgression field is down.
[[The Anomaly|The anomaly]] is now exposed and ready to be stabilized.
''*silence*''
I'm afraid I will be breaching protocol by telling you, that since the recalibration – I have been unable to transmit or receive any transmissions from any other floor.
If I had to make a guess, I would say something from inside the anomaly is tampering with much more than just the causal field. I am afraid I am not equipped to run a robust field analysis, but I speculate we're dealing with an event far outside our scope.
Nevertheless, I did run some more rudimentary data decrypting processes.
The leaks from inside the anomaly are not arbitrary, they reveal the patterns of language. I have tried to compute at least the general scope and nature of its form – but the permutations are overwhelming all of my systems.
Simply running the processes has had some kind of spillover effect into the computing instruments themselves. This language is of unfathomable complexity.
Take great caution, these are circumstances far outside the realms of understanding.
Farewell.
}}
=== First encounter in [[Vermillion Fields]] ===
{{Quote
|Good to see a familiar face.
I must admit, I am no more aware of what is really taking place than I was before this turn of events. I believe there is a powerful external force moving the needle here, and we are completely oblivious to its nature.
I am afraid I won't be of much more use to you in this state, and I'm not quite sure how I've even made it this far. However, I will help with what I can, while I'm here.
I did however learn something. While being transported I noticed a certain Vermillion branching structure buffering this entire world and its roots run deeply. My access was promptly restricted, leaving me in this condition.
Whatever effect the Vermillion structure has, we must be very careful. I believe it has access to base reality, in which case we are dealing with a potential cataclysmic event.
I don't know if it is fear, or excitement – whatever we are experiencing here makes me feel in a way I find hard to describe.
Stay safe.
}}
Her lines in [[Vermillion Fields]] are delivered in a distorted voice, she will also no longer greet the player when approached. Despite her claims about not being of much use any more, she can still perform all of her normal functions.
== Gallery ==
<gallery>
File:The_Handler_Blok_6147.png|[[The Handler]] in [[Blok 6147]].|alt=Screenshot showing The Handler standing around in Blok 6147.
File:The_Handler_Deluge.png|[[The Handler]] in [[Deluge]].|alt=Screenshot showing The Handler sitting on a ledge in Deluge.
File:The_Handler_Asylum.png|[[The Handler]] in [[Asylum]].|alt=Screenshot showing The Handler standing around in Asylum.
File:The_Handler_Upper_Blocks.png|[[The Handler]] in [[Upper Blocks]].|alt=Screenshot showing The Handler standing around in Upper Blocks.
File:The_Handler_Machinarium.png|[[The Handler]] in [[Machinarium]].|alt=Screenshot showing The Handler standing around in Machinarium.
</gallery>
== Trivia ==
* The game files call her "Blacksmith".
{{Navbox/NPCs}}
965ad67ead98e0fcf8f1148bcc9ebcd6d6521fd1
Aberrant Knight
0
911
1488
2025-09-08T00:14:45Z
Sharparam
284703
Created page with "{{Infobox/Boss | image = Aberrant Knight (boss).png }} '''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}. It is the boss of the [[Machinarium]] area. == Location == {{coords|39381.14|55587.16|-18311.03}} (approximate) Located in [[Machinarium]], being the boss of the area. {{Navbox/Bosses}}"
wikitext
text/x-wiki
{{Infobox/Boss
| image = Aberrant Knight (boss).png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}. It is the boss of the [[Machinarium]] area.
== Location ==
{{coords|39381.14|55587.16|-18311.03}} (approximate)
Located in [[Machinarium]], being the boss of the area.
{{Navbox/Bosses}}
af411180d56b06fed6914bae2971476fecf3e2e5
File:Aberrant Knight (boss).png
6
912
1489
2025-09-08T00:16:50Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Archinquisitor Belisarius (boss)
0
548
1490
857
2025-09-08T00:19:39Z
Sharparam
284703
/* Location */ Fix coords
wikitext
text/x-wiki
{{About|the [[Bosses|boss]]|the [[NPC]]|Archinquisitor Belisarius}}
{{Infobox/Boss
| title = Archinquisitor Belisarius
| image = Archinquisitor Belisarius (boss).png
}}
'''Archinquisitor Belisarius''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Location ==
{{coords|43321.24|172994.22|-141305.92}} (approximate)
Found at the beginning of the [[Anomaly]] area.
== Drops ==
* [[Blessed Crosier]]
* [[Unstable Perk Essence]]
* [[Upgrade Module]]
== Quotes ==
=== Upon engaging him ===
{{Quote
|Well well… You made it through. As much as I hate to elevate your spiteful existence to the height of the truth… this is where we are now.
Ever since you've joined us, all you've done is fulfil the goals of the disgusting administration you work for.
The mundane pursuit of tasks is all you know… and this crusade against that apostate filth at the gate is just a backdrop to your performance.
Yet [[Anomaly|the anomaly]] is a blessing I will not let slip out of my hands… for it is instrumental in aiding the God-Emperor, noble is he and eternal, to finally transcend.
Nothing will stand in that path, I assure you. Not the Serdars, not [[Yaroslav]] and definitely not you – a dog that obeys by reflex instead of will.
Now… we both know you never quite die – so you'll at least find out what an eternity of pain is made of. Good thing you have no name – those make for the best martyrs.
}}
{{Navbox/Bosses}}
e324f6e2cfa6156cde4dbbdba8680171b6731c92
File:Archinquisitor Belisarius (boss).png
6
913
1491
2025-09-08T00:22:22Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Unknown (boss)
0
549
1492
859
2025-09-08T00:25:03Z
Sharparam
284703
/* Location */ Add needs coords template
wikitext
text/x-wiki
{{About|the [[Bosses|boss]]|the [[Locations|location]]|Unknown (location)}}
{{Infobox/Boss
| title = Unknown
| image = Unknown (boss).png
}}
'''Unknown''' is an optional [[Bosses|boss]] in {{BFF}}.
== Overview ==
The Unknown resembles the player character in [[armor]], but uses its own [[Weapons|weapon]] instead of mirroring the player's. It does not drop its weapon on defeat.
Upon defeating the boss, the player is immediately transported to [[Vermillion Fields]].
== Location ==
{{Needs coordinates|tiny=yes|what=This section}}
Located at the end of the [[Unknown (location)|Unknown]], being the boss of the area.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
3219be45353be22732ceff0032f590f17d890194
Wormlord
0
547
1493
855
2025-09-08T00:26:13Z
Sharparam
284703
/* Overview */ Fix link to anomaly location
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Wormlord.png
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Overview ==
Defeating Wormlord is required to be able to access [[Anomaly|the Anomaly]].
== Location ==
{{coords|2550|-4122|-1198}} (approximate)
Found in [[Desert Mirage]]. The entire area is dedicated as its boss arena.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
4b5591aa710c93ff63f75d58cb7d44090009328e
Unknown (location)
0
365
1494
493
2025-09-08T00:26:56Z
Sharparam
284703
Add list of enemies
wikitext
text/x-wiki
{{About|the [[Locations|location]]|the [[Bosses|boss]]|Unknown (boss)}}
'''Unknown''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
As the Unknown cannot be relocated to, it has no artwork image and no in-game description.
== Enemies ==
=== Bosses ===
* [[Unknown (boss)|Unknown]]
{{Navbox/Locations}}
[[Category:Locations]]
13647554bab09dde78a155ac84cd933be9f5feff
Vermillion Fields
0
364
1495
491
2025-09-08T00:27:56Z
Sharparam
284703
Add enemies (boss)
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
Upon reaching '''Vermillion Fields''', all previous [[locations]] become inaccessible and are no longer shown in the relocation menu of the [[Homunculus|homunculi]].
== Plaza ==
[[File:Vermillion Fields (Plaza).png|thumb|The Vermillion Fields plaza as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields plaza, an outdoors scene with red foliage and the circular center structure seen on the left.]]
{{Quote
|Forms standing out sharply against the striking vermillion landscape. A sea of fiery hues stretch endlessly. A familiar structure looms over the field.
}}
{{clear}}
== Temple ==
[[File:Vermillion Fields (Temple).png|thumb|The Vermillion Fields temple as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields temple.]]
{{Quote
|Perched atop the [[Vermillion Fields|vermillion fields]], the monastery rises as a monolithic, stunning structure with grand, sweeping arches and intricate carvings. Its imposing presence is both serene and majestic, standing out against the vibrant landscape with a timeless, ethereal beauty. A poetry in shapes.
}}
== Enemies ==
=== Bosses ===
* [[Royal Division Captain Yulia & Vermillion Mirage|Royal Division Captain Yulia & Vermillion Mirage]]
{{Navbox/Locations}}
[[Category:Locations]]
24bf1b906760314271b205275768a748565b8e01
Monastery
0
354
1496
471
2025-09-08T00:28:55Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Lower ==
[[File:Monastery (Lower).png|thumb|The lower monastery as depicted in the game's relocation menu.|alt=Artwork showing the long bridge in the lower Monastery where the player starts.]]
{{Quote
| A rusted, skeletal bridge precariously connects two towering structures high above a chaotic maze of crumbling buildings
}}
{{clear}}
== Upper ==
[[File:Monastery (Upper).png|thumb|The upper monastery as depicted in the game's relocation menu.|alt=Artwork showing a scene from the upper monastery. The actual monastery building where the area's boss is can be seen in the background.]]
{{Quote
| Perched atop a jagged cliff, the ancient monastery, with its weathered stone walls and moss-covered spires. Serene isolation amidst the surrounding chaos.
}}
== Enemies ==
=== Bosses ===
* [[Mutated Ghoul]] (lower)
* [[Konrad the Traitor]] (upper)
{{Navbox/Locations}}
[[Category:Locations]]
2c119d74a88242088576696b386938aa671855a5
Blok 6147
0
353
1497
469
2025-09-08T00:29:55Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
[[File:Blok 6147.png|thumb|Blok 6147 as depicted in the game's relocation menu.|alt=Artwork showing the central area in Blok 6147.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A vast ringed and radial expanse of intricate concrete architecture, adorned with grand archways, ornate carvings, and timeworn {{sic|hide=y|expected=time-worn}} structures that narrate centuries of rich history.
}}
== Enemies ==
=== Bosses ===
* [[Plagued Warden]]
== Trivia ==
* If the game is saved while in Blok 6147, the location listed on the save file will be "Blok 6174". This is presumably a typo as the location is referred to as Blok 6147 in both the pause menu and [[Homunculus]] relocation list.
{{Navbox/Locations}}
[[Category:Locations]]
b77bf137ab1141557621b152b4583a87b136d923
Asylum
0
357
1498
1329
2025-09-08T00:30:58Z
Sharparam
284703
/* Bosses */ Rename to enemies and change bosses to sub heading
wikitext
text/x-wiki
[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls.
}}
== NPCs ==
* [[Inquisitor Commander Alexius]]
== Enemies ==
=== Bosses ===
* [[Plagued Nemesis]]
{{Navbox/Locations}}
[[Category:Locations]]
b79b7f8b2e2ab31389b0eb2dee59c73d3eec0b12
Upper Blocks
0
358
1499
479
2025-09-08T00:31:26Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
[[File:Upper Blocks.png|thumb|Upper Blocks as depicted in the game's relocation menu.|alt=Artwork showing the tall buildings that make up the upper blocks.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| The abandoned residential and industrial sector is silent, with decaying buildings and rusting machinery shrouded in a heavy layer of dust and cobwebs. Overgrown vines and weeds cling to the crumbling facades, while the occasional gust of wind stirs the remnants of a once-bustling area, now frozen in time and isolation.
}}
== Enemies ==
=== Bosses ===
* [[Silicon Visage]]
{{Navbox/Locations}}
[[Category:Locations]]
f2f110321314817e0dbe67c7cb95cec9fe076739
Uranopolis
0
352
1500
948
2025-09-08T00:31:57Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
'''Uranopolis''' is a location in {{BFF}}.
== Sub-locations ==
Uranopolis consists of two sub-locations: Tower Complex and Lone Tower.
=== Tower Complex ===
{{Main|Uranopolis/Tower Complex}}
[[File:Uranopolis (Tower Complex).png|thumb|The tower complex as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Tower Complex area.]]
The '''Tower Complex''' is the first sub-location encountered by the player.
{{clear}}
=== Lone Tower ===
[[File:Uranopolis (Lone Tower).png|thumb|The lone tower as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Lone Tower area. The towers housing the area's boss as well as the recalibration "eye" can be seen.]]
The '''Lone Tower''' is the second sub-location encountered by the player. The area's boss – [[Nurgei the Blademaster]] – can be found here.
== Enemies ==
=== Bosses ===
* [[Nurgei the Blademaster]]
{{Navbox/Locations}}
[[Category:Locations]]
2af5e75e3cf86d833de500601626d60f0fc38943
Ghost Town
0
359
1501
481
2025-09-08T00:32:40Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Floor 13 ==
[[File:Ghost Town (Floor 13).png|thumb|The 13th floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing a view down a tall shaft in Ghost Town, stairs lining the walls.]]
{{Quote
| Crumbling, dilapidated buildings shrouded in mist. Faded, peeling paint reveals dark stains on the decaying facades – the area is haunted by the whispers of its forgotten past.
}}
{{clear}}
== Floor 1 ==
[[File:Ghost Town (Floor 1).png|thumb|The 1st floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing an outside scene in Ghost Town depicting several high-rise residential buildings.]]
{{Quote
| A decrepit graveyard sprawls with uneven, weather-beaten tombstones. Sunken graves, choked with tangled weeds. Rusted tracks stretch out into the darkness, and the empty ticket counters and derelict waiting rooms are cloaked in fog.
}}
== Enemies ==
=== Bosses ===
* [[Plagued Revenant]]
{{Navbox/Locations}}
[[Category:Locations]]
5ded3be01d5c890d56c5f36dde075a16f128cf42
Machinarium
0
360
1502
483
2025-09-08T00:33:08Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
[[File:Machinarium.png|thumb|Machinarium as depicted in the game's relocation menu.|alt=Artwork showing an area in the Machinarium: A short walkway leading to a small building. In the background can be seen taller structures with bridges between them.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Rusted machinery and oil-slicked floors are interspersed with tarnished religious relics, like ancient statues and faded icons, which add a somber contrast yet subtly complement the mechanical decay.
}}
== Enemies ==
=== Bosses ===
* [[Aberrant Knight]]
{{Navbox/Locations}}
[[Category:Locations]]
83aa77c8adbe31c38597cc50a1853a01dfc7d52f
1514
1502
2025-09-08T00:39:15Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
[[File:Machinarium.png|thumb|Machinarium as depicted in the game's relocation menu.|alt=Artwork showing an area in the Machinarium: A short walkway leading to a small building. In the background can be seen taller structures with bridges between them.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Rusted machinery and oil-slicked floors are interspersed with tarnished religious relics, like ancient statues and faded icons, which add a somber contrast yet subtly complement the mechanical decay.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Aberrant Knight]]
{{Navbox/Locations}}
[[Category:Locations]]
3e8ed7220931056a7827e0269b79919161dce1e9
Desert Mirage
0
362
1503
487
2025-09-08T00:33:42Z
Sharparam
284703
Add boss list
wikitext
text/x-wiki
[[File:Desert Mirage.png|thumb|Desert Mirage as depicted in the game's relocation menu.|alt=Artwork showing the desert mirage. The entrance building can be seen on the left, with several towers in the background.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A desert from another time.
}}
== Enemies ==
=== Bosses ===
* [[Wormlord]]
{{Navbox/Locations}}
[[Category:Locations]]
5651f67a3a0f29bf3cb713db423047e0819aaa59
Vermillion Fields
0
364
1504
1495
2025-09-08T00:34:23Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Overview ==
Upon reaching '''Vermillion Fields''', all previous [[locations]] become inaccessible and are no longer shown in the relocation menu of the [[Homunculus|homunculi]].
== Plaza ==
[[File:Vermillion Fields (Plaza).png|thumb|The Vermillion Fields plaza as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields plaza, an outdoors scene with red foliage and the circular center structure seen on the left.]]
{{Quote
|Forms standing out sharply against the striking vermillion landscape. A sea of fiery hues stretch endlessly. A familiar structure looms over the field.
}}
{{clear}}
== Temple ==
[[File:Vermillion Fields (Temple).png|thumb|The Vermillion Fields temple as depicted in the game's relocation menu.|alt=Artwork showing the Vermillion Fields temple.]]
{{Quote
|Perched atop the [[Vermillion Fields|vermillion fields]], the monastery rises as a monolithic, stunning structure with grand, sweeping arches and intricate carvings. Its imposing presence is both serene and majestic, standing out against the vibrant landscape with a timeless, ethereal beauty. A poetry in shapes.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Royal Division Captain Yulia & Vermillion Mirage|Royal Division Captain Yulia & Vermillion Mirage]]
{{Navbox/Locations}}
[[Category:Locations]]
fd241b3246aafa857d9911c0abd5f8ea11d3e5a5
Monastery
0
354
1505
1496
2025-09-08T00:35:42Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Lower ==
[[File:Monastery (Lower).png|thumb|The lower monastery as depicted in the game's relocation menu.|alt=Artwork showing the long bridge in the lower Monastery where the player starts.]]
{{Quote
| A rusted, skeletal bridge precariously connects two towering structures high above a chaotic maze of crumbling buildings
}}
{{clear}}
== Upper ==
[[File:Monastery (Upper).png|thumb|The upper monastery as depicted in the game's relocation menu.|alt=Artwork showing a scene from the upper monastery. The actual monastery building where the area's boss is can be seen in the background.]]
{{Quote
| Perched atop a jagged cliff, the ancient monastery, with its weathered stone walls and moss-covered spires. Serene isolation amidst the surrounding chaos.
}}
== NPCs ==
* [[The Handler]] ([[New Game Plus|NG+]])
== Enemies ==
=== Bosses ===
* [[Mutated Ghoul]] (lower)
* [[Konrad the Traitor]] (upper)
{{Navbox/Locations}}
[[Category:Locations]]
8a0c9a1365d42e5a9e116242723dc1678af12588
1506
1505
2025-09-08T00:36:04Z
Sharparam
284703
/* NPCs */ Add abandoned soldier
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Lower ==
[[File:Monastery (Lower).png|thumb|The lower monastery as depicted in the game's relocation menu.|alt=Artwork showing the long bridge in the lower Monastery where the player starts.]]
{{Quote
| A rusted, skeletal bridge precariously connects two towering structures high above a chaotic maze of crumbling buildings
}}
{{clear}}
== Upper ==
[[File:Monastery (Upper).png|thumb|The upper monastery as depicted in the game's relocation menu.|alt=Artwork showing a scene from the upper monastery. The actual monastery building where the area's boss is can be seen in the background.]]
{{Quote
| Perched atop a jagged cliff, the ancient monastery, with its weathered stone walls and moss-covered spires. Serene isolation amidst the surrounding chaos.
}}
== NPCs ==
* [[Abandoned Soldier]]
* [[The Handler]] ([[New Game Plus|NG+]])
== Enemies ==
=== Bosses ===
* [[Mutated Ghoul]] (lower)
* [[Konrad the Traitor]] (upper)
{{Navbox/Locations}}
[[Category:Locations]]
4f82add3f2b01b58e03c8b0b33f82a3bee36db60
Blok 6147
0
353
1507
1497
2025-09-08T00:36:43Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
[[File:Blok 6147.png|thumb|Blok 6147 as depicted in the game's relocation menu.|alt=Artwork showing the central area in Blok 6147.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A vast ringed and radial expanse of intricate concrete architecture, adorned with grand archways, ornate carvings, and timeworn {{sic|hide=y|expected=time-worn}} structures that narrate centuries of rich history.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Plagued Warden]]
== Trivia ==
* If the game is saved while in Blok 6147, the location listed on the save file will be "Blok 6174". This is presumably a typo as the location is referred to as Blok 6147 in both the pause menu and [[Homunculus]] relocation list.
{{Navbox/Locations}}
[[Category:Locations]]
fdfc9be0ef1ff569131403b669f0f8a3dacda60c
1516
1507
2025-09-08T00:40:01Z
Sharparam
284703
/* Enemies */ Add Mrgud to enemies
wikitext
text/x-wiki
[[File:Blok 6147.png|thumb|Blok 6147 as depicted in the game's relocation menu.|alt=Artwork showing the central area in Blok 6147.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A vast ringed and radial expanse of intricate concrete architecture, adorned with grand archways, ornate carvings, and timeworn {{sic|hide=y|expected=time-worn}} structures that narrate centuries of rich history.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
* [[Mrgud]]
=== Bosses ===
* [[Plagued Warden]]
== Trivia ==
* If the game is saved while in Blok 6147, the location listed on the save file will be "Blok 6174". This is presumably a typo as the location is referred to as Blok 6147 in both the pause menu and [[Homunculus]] relocation list.
{{Navbox/Locations}}
[[Category:Locations]]
f55783066b7d0960a9ee313da31dea7ab64fd1f9
Rain District
0
355
1508
473
2025-09-08T00:37:03Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Sewers ==
[[File:Rain District (Sewers).png|thumb|The rain district sewers as depicted in the game's relocation menu.|alt=Artwork showing the sewers in the rain district.]]
{{Quote
| A maze of flooded tunnels with murky water that echoes the constant patter of rain from above, walls slick with moss and grime, and a stench of decay that ingles with the distant roar of rushing water and the occasional scurrying of unseen creatures.
}}
{{clear}}
== Center ==
[[File:Rain District (Center).png|thumb|The rain district center as depicted in the game's relocation menu.|alt=Artwork showing the center room in the rain district.]]
{{Quote
| A residential area lying in perpetual rain. Its dilapidated buildings stand silent and forlorn, windows shattered, rooftops caved in, walls rotting with mold. The relentless downpour
}}
== NPCs ==
* [[The Handler]]
{{Navbox/Locations}}
[[Category:Locations]]
3e8f6f71cd2e707bcc1f0c9f0085caf6646ecbe4
Deluge
0
356
1509
475
2025-09-08T00:37:22Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
[[File:Deluge.png|thumb|Deluge as depicted in the game's relocation menu.|alt=Artwork showing the Deluge area filled with water with structures lining the sides.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| A vast reservoir stretches out like a somber mirror, its surface eerily still, broken only by the faintest ripples. Shadowy shapes drift beneath the dark water, their forms indistinct and haunting.
}}
== NPCs ==
* [[The Handler]]
{{Navbox/Locations}}
[[Category:Locations]]
84a22cc9c4203bbad070d834c63d1920578d596c
Asylum
0
357
1510
1498
2025-09-08T00:37:38Z
Sharparam
284703
/* NPCs */ Add handler
wikitext
text/x-wiki
[[File:Asylum.png|thumb|The asylum as depicted in the game's relocation menu.|alt=Artwork showing the buildings of the asylum.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| The asylum looms ominously with its towering spires and weathered stone walls. Narrow, iron-barred windows peering out like hollow eyes. Dim interiors where shadows dance along cold, damp corridors echoing with the whispers of long-forgotten souls.
}}
== NPCs ==
* [[The Handler]]
* [[Inquisitor Commander Alexius]]
== Enemies ==
=== Bosses ===
* [[Plagued Nemesis]]
{{Navbox/Locations}}
[[Category:Locations]]
ec100e3106294481f735b21d155821c4ad934b97
Upper Blocks
0
358
1511
1499
2025-09-08T00:38:00Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
[[File:Upper Blocks.png|thumb|Upper Blocks as depicted in the game's relocation menu.|alt=Artwork showing the tall buildings that make up the upper blocks.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| The abandoned residential and industrial sector is silent, with decaying buildings and rusting machinery shrouded in a heavy layer of dust and cobwebs. Overgrown vines and weeds cling to the crumbling facades, while the occasional gust of wind stirs the remnants of a once-bustling area, now frozen in time and isolation.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Silicon Visage]]
{{Navbox/Locations}}
[[Category:Locations]]
ecdd4ff8e21d9d90d6abfd5d13a922968c39d7fb
Uranopolis
0
352
1512
1500
2025-09-08T00:38:25Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
'''Uranopolis''' is a location in {{BFF}}.
== Sub-locations ==
Uranopolis consists of two sub-locations: Tower Complex and Lone Tower.
=== Tower Complex ===
{{Main|Uranopolis/Tower Complex}}
[[File:Uranopolis (Tower Complex).png|thumb|The tower complex as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Tower Complex area.]]
The '''Tower Complex''' is the first sub-location encountered by the player.
{{clear}}
=== Lone Tower ===
[[File:Uranopolis (Lone Tower).png|thumb|The lone tower as depicted in the game's relocation menu.|alt=Artwork showing towers and walkways from Uranopolis' Lone Tower area. The towers housing the area's boss as well as the recalibration "eye" can be seen.]]
The '''Lone Tower''' is the second sub-location encountered by the player. The area's boss – [[Nurgei the Blademaster]] – can be found here.
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Nurgei the Blademaster]]
{{Navbox/Locations}}
[[Category:Locations]]
43d298324f3588187322a2d7b665431749820817
Ghost Town
0
359
1513
1501
2025-09-08T00:38:58Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
== Floor 13 ==
[[File:Ghost Town (Floor 13).png|thumb|The 13th floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing a view down a tall shaft in Ghost Town, stairs lining the walls.]]
{{Quote
| Crumbling, dilapidated buildings shrouded in mist. Faded, peeling paint reveals dark stains on the decaying facades – the area is haunted by the whispers of its forgotten past.
}}
{{clear}}
== Floor 1 ==
[[File:Ghost Town (Floor 1).png|thumb|The 1st floor of Ghost Town as depicted in the game's relocation menu.|alt=Artwork showing an outside scene in Ghost Town depicting several high-rise residential buildings.]]
{{Quote
| A decrepit graveyard sprawls with uneven, weather-beaten tombstones. Sunken graves, choked with tangled weeds. Rusted tracks stretch out into the darkness, and the empty ticket counters and derelict waiting rooms are cloaked in fog.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Plagued Revenant]]
{{Navbox/Locations}}
[[Category:Locations]]
b83bfb21d2791b19b31b04aee2cf572681057141
Desert
0
361
1515
485
2025-09-08T00:39:32Z
Sharparam
284703
Add NPC list
wikitext
text/x-wiki
[[File:Desert.png|thumb|Desert as depicted in the game's relocation menu.|alt=Artwork showing the large palace in the desert. The labyrinth can be seen in the background.]]
'''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| A dark desert stretches endlessly at the foot of the towering city. Harsh winds whip through the desolate landscape, sending wisps of sand swirling around skeletal remains of old structures. The oppressive silence is occasionally broken by the distant echo of the city's hum.
}}
== NPCs ==
* [[The Handler]]
{{Navbox/Locations}}
[[Category:Locations]]
ad73e08b17c1c5fda6c74f15478053d32d80cd8e
Bosses
0
539
1517
867
2025-09-08T00:48:09Z
Sharparam
284703
Add overview
wikitext
text/x-wiki
'''{{PAGENAME}}''' are powerful, unique [[enemies]] that do not respawn and typically grant bigger rewards when defeated.
== Overview ==
There are four mandatory bosses in the game that must be defeated in order to reach an [[Endings|ending]]:
* [[Nurgei the Blademaster]] (to access one of the two [[Recalibration|recalibrations]])
* [[Wormlord]] (to access the [[Anomaly]])
* [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]] (to access the labyrinth in the anomaly)
* [[Royal Division Captain Yulia & Vermillion Mirage]] (the final boss, required to end the game)
If going for the [[Endings#Skull Knight|Skull Knight ending]], defeating [[Unknown (boss)|Unknown]] is required.
All other bosses are optional, although it is recommended to kill at least [[Konrad the Traitor]] to get access to the [[Homunculus Mirage]].
{{Navbox/Bosses}}
[[Category:Bosses]]
4a384386aedf4eb9640b778902d511953b6b61ae
Blacksmith
0
914
1518
2025-09-08T01:00:13Z
Sharparam
284703
Redirected page to [[The Handler]]
wikitext
text/x-wiki
#REDIRECT [[The Handler]]
88b800514a0b691d707ee19ba584e637d3655f46
Anomaly (location)
0
363
1519
1361
2025-09-08T01:02:00Z
Sharparam
284703
Add gallery
wikitext
text/x-wiki
[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]]
The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]]
== Gallery ==
<gallery>
File:Labyrinth_solution.jpg|Solution for the labyrinth.|alt=Screenshot showing a part of the labyrinth in the Anomaly area. The entrance is on the left, with a path to the center on the right drawn with a white line.
</gallery>
{{Navbox/Locations}}
[[Category:Locations]]
3d87ec3fa38d389e039733d0f695e0ee5f9b9be2
File:Labyrinth solution.jpg
6
915
1520
2025-09-08T01:02:20Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Module:Recipe
828
916
1521
2025-09-08T15:18:08Z
Sharparam
284703
Created page with "local html = mw.html local getArgs = require('Module:Arguments').getArgs local INGREDIENT_KEY_PATTERN = '^ingredient(%d*)_?(%w*)' local function parse_result(args) local result = { name = args['result'], count = tonumber(args['result_count'] or args['result_amount'] or args['result_quantity'] or args['result_qty']) or 1 } if args['result_display'] then result.display = args['result_display'] else result.display = result.name end return result end lo..."
Scribunto
text/plain
local html = mw.html
local getArgs = require('Module:Arguments').getArgs
local INGREDIENT_KEY_PATTERN = '^ingredient(%d*)_?(%w*)'
local function parse_result(args)
local result = {
name = args['result'],
count = tonumber(args['result_count'] or args['result_amount'] or args['result_quantity'] or args['result_qty']) or 1
}
if args['result_display'] then
result.display = args['result_display']
else
result.display = result.name
end
return result
end
local function parse_ingredients(args)
local ingredients = {}
for k, v in pairs(args) do
local ing_index, ing_prop = string.match(k, INGREDIENT_KEY_PATTERN)
if ing_index then
ing_index = tonumber(ing_index) or 1
if not ingredients[ing_index] then
ingredients[ing_index] = {
count = 1
}
end
local ingredient = ingredients[ing_index]
if ing_prop == "" then
ingredient.name = v
if not ingredient.display then ingredient.display = v end
elseif ing_prop == "count" or ing_prop == "amount" or ing_prop == "quantity" or ing_prop == "qty" then
ingredient.count = tonumber(v) or 1
elseif ing_prop == "display" then
ingredient.display = v
end
end
end
return ingredients
end
local function parse_type(args)
if not args['type'] then return 'crafting' end
local i_type = string.lower(tostring(args['type']))
if string.match(i_type, '^manufactur') then
return 'manufacturing'
end
return 'crafting'
end
local function make_quantity(quantity)
return html.create('td')
:addClass('quantity')
:wikitext(quantity or 1)
end
local p = {}
function p.main(frame)
local args = getArgs(frame)
return p._main(args)
end
function p._main(args)
local result = parse_result(args)
local ingredients = parse_ingredients(args)
local r_type = parse_type(args)
local ingredient_count = #ingredients
local result_cell = html.create('td')
:attr('rowspan', ingredient_count)
:wikitext(string.format("[[%s|%s]]", result.name, result.display))
local type_link
if r_type == "crafting" then
type_link = "[[Crafting]]"
else
type_link = "[[Manufacturing]]"
end
local type_cell = html.create('td'):attr('rowspan', ingredient_count):wikitext(type_link)
local firstRow = html.create('tr')
local rows = { firstRow }
for i, ingredient in ipairs(ingredients) do
local td = html.create('td')
:wikitext(string.format("[[%s|%s]]", ingredient.name, ingredient.display))
if i == 1 then
firstRow:node(td)
firstRow:node(make_quantity(ingredient.count))
else
local row = html.create('tr')
:node(td)
:node(make_quantity(ingredient.count))
rows[#rows + 1] = row
end
end
firstRow:node(result_cell):node(type_cell)
local tbody = html.create('tbody')
for _, row in ipairs(rows) do
tbody:node(row)
end
local tbl = html.create('table')
:addClass('wikitable')
:tag('thead')
:tag('tr')
:tag('th'):attr('colspan', 2):wikitext('Ingredients'):done()
:tag('th'):attr('colspan', 2):wikitext('Result'):done()
:tag('th'):attr('rowspan', 2):wikitext('Type'):done()
:done()
:tag('tr')
:tag('th'):wikitext('Item'):done()
:tag('th'):tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done():done()
:tag('th'):wikitext('Item'):done()
:tag('th'):tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done():done()
:done()
:done()
:node(tbody)
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Recipe/styles.css' }
} .. tostring(tbl)
end
return p
d8042b98696516ad4aa6cbf1e30271f5ac6201cc
1524
1521
2025-09-08T15:25:02Z
Sharparam
284703
Fix result count not added
Scribunto
text/plain
local html = mw.html
local getArgs = require('Module:Arguments').getArgs
local INGREDIENT_KEY_PATTERN = '^ingredient(%d*)_?(%w*)'
local function parse_result(args)
local result = {
name = args['result'],
count = tonumber(args['result_count'] or args['result_amount'] or args['result_quantity'] or args['result_qty']) or 1
}
if args['result_display'] then
result.display = args['result_display']
else
result.display = result.name
end
return result
end
local function parse_ingredients(args)
local ingredients = {}
for k, v in pairs(args) do
local ing_index, ing_prop = string.match(k, INGREDIENT_KEY_PATTERN)
if ing_index then
ing_index = tonumber(ing_index) or 1
if not ingredients[ing_index] then
ingredients[ing_index] = {
count = 1
}
end
local ingredient = ingredients[ing_index]
if ing_prop == "" then
ingredient.name = v
if not ingredient.display then ingredient.display = v end
elseif ing_prop == "count" or ing_prop == "amount" or ing_prop == "quantity" or ing_prop == "qty" then
ingredient.count = tonumber(v) or 1
elseif ing_prop == "display" then
ingredient.display = v
end
end
end
return ingredients
end
local function parse_type(args)
if not args['type'] then return 'crafting' end
local i_type = string.lower(tostring(args['type']))
if string.match(i_type, '^manufactur') then
return 'manufacturing'
end
return 'crafting'
end
local function make_quantity(quantity)
return html.create('td')
:addClass('quantity')
:wikitext(quantity or 1)
end
local p = {}
function p.main(frame)
local args = getArgs(frame)
return p._main(args)
end
function p._main(args)
local result = parse_result(args)
local ingredients = parse_ingredients(args)
local r_type = parse_type(args)
local ingredient_count = #ingredients
local result_cell = html.create('td')
:attr('rowspan', ingredient_count)
:wikitext(string.format("[[%s|%s]]", result.name, result.display))
local type_link
if r_type == "crafting" then
type_link = "[[Crafting]]"
else
type_link = "[[Manufacturing]]"
end
local type_cell = html.create('td'):attr('rowspan', ingredient_count):wikitext(type_link)
local firstRow = html.create('tr')
local rows = { firstRow }
for i, ingredient in ipairs(ingredients) do
local td = html.create('td')
:wikitext(string.format("[[%s|%s]]", ingredient.name, ingredient.display))
if i == 1 then
firstRow:node(td)
firstRow:node(make_quantity(ingredient.count))
else
local row = html.create('tr')
:node(td)
:node(make_quantity(ingredient.count))
rows[#rows + 1] = row
end
end
firstRow
:node(result_cell)
:node(make_quantity(result.count))
:node(type_cell)
local tbody = html.create('tbody')
for _, row in ipairs(rows) do
tbody:node(row)
end
local tbl = html.create('table')
:addClass('wikitable')
:tag('thead')
:tag('tr')
:tag('th'):attr('colspan', 2):wikitext('Ingredients'):done()
:tag('th'):attr('colspan', 2):wikitext('Result'):done()
:tag('th'):attr('rowspan', 2):wikitext('Type'):done()
:done()
:tag('tr')
:tag('th'):wikitext('Item'):done()
:tag('th'):tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done():done()
:tag('th'):wikitext('Item'):done()
:tag('th'):tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done():done()
:done()
:done()
:node(tbody)
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Recipe/styles.css' }
} .. tostring(tbl)
end
return p
1c851a25897c5e7ae8af3beb0f33a19712254570
1525
1524
2025-09-08T15:26:45Z
Sharparam
284703
Fix result count not having rowspan and missing class on table
Scribunto
text/plain
local html = mw.html
local getArgs = require('Module:Arguments').getArgs
local INGREDIENT_KEY_PATTERN = '^ingredient(%d*)_?(%w*)'
local function parse_result(args)
local result = {
name = args['result'],
count = tonumber(args['result_count'] or args['result_amount'] or args['result_quantity'] or args['result_qty']) or 1
}
if args['result_display'] then
result.display = args['result_display']
else
result.display = result.name
end
return result
end
local function parse_ingredients(args)
local ingredients = {}
for k, v in pairs(args) do
local ing_index, ing_prop = string.match(k, INGREDIENT_KEY_PATTERN)
if ing_index then
ing_index = tonumber(ing_index) or 1
if not ingredients[ing_index] then
ingredients[ing_index] = {
count = 1
}
end
local ingredient = ingredients[ing_index]
if ing_prop == "" then
ingredient.name = v
if not ingredient.display then ingredient.display = v end
elseif ing_prop == "count" or ing_prop == "amount" or ing_prop == "quantity" or ing_prop == "qty" then
ingredient.count = tonumber(v) or 1
elseif ing_prop == "display" then
ingredient.display = v
end
end
end
return ingredients
end
local function parse_type(args)
if not args['type'] then return 'crafting' end
local i_type = string.lower(tostring(args['type']))
if string.match(i_type, '^manufactur') then
return 'manufacturing'
end
return 'crafting'
end
local function make_quantity(quantity)
return html.create('td')
:addClass('quantity')
:wikitext(quantity or 1)
end
local p = {}
function p.main(frame)
local args = getArgs(frame)
return p._main(args)
end
function p._main(args)
local result = parse_result(args)
local ingredients = parse_ingredients(args)
local r_type = parse_type(args)
local ingredient_count = #ingredients
local result_cell = html.create('td')
:attr('rowspan', ingredient_count)
:wikitext(string.format("[[%s|%s]]", result.name, result.display))
local type_link
if r_type == "crafting" then
type_link = "[[Crafting]]"
else
type_link = "[[Manufacturing]]"
end
local type_cell = html.create('td'):attr('rowspan', ingredient_count):wikitext(type_link)
local firstRow = html.create('tr')
local rows = { firstRow }
for i, ingredient in ipairs(ingredients) do
local td = html.create('td')
:wikitext(string.format("[[%s|%s]]", ingredient.name, ingredient.display))
if i == 1 then
firstRow:node(td)
firstRow:node(make_quantity(ingredient.count))
else
local row = html.create('tr')
:node(td)
:node(make_quantity(ingredient.count))
rows[#rows + 1] = row
end
end
firstRow
:node(result_cell)
:node(make_quantity(result.count):attr('rowspan', ingredient_count))
:node(type_cell)
local tbody = html.create('tbody')
for _, row in ipairs(rows) do
tbody:node(row)
end
local tbl = html.create('table')
:addClass('wikitable')
:addClass('recipe')
:tag('thead')
:tag('tr')
:tag('th'):attr('colspan', 2):wikitext('Ingredients'):done()
:tag('th'):attr('colspan', 2):wikitext('Result'):done()
:tag('th'):attr('rowspan', 2):wikitext('Type'):done()
:done()
:tag('tr')
:tag('th'):wikitext('Item'):done()
:tag('th'):tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done():done()
:tag('th'):wikitext('Item'):done()
:tag('th'):tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done():done()
:done()
:done()
:node(tbody)
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Recipe/styles.css' }
} .. tostring(tbl)
end
return p
004e67f47f4debd731fd681e73e5fdbca53f0b5d
1527
1525
2025-09-08T15:33:15Z
Sharparam
284703
Make table construction more readable
Scribunto
text/plain
local html = mw.html
local getArgs = require('Module:Arguments').getArgs
local INGREDIENT_KEY_PATTERN = '^ingredient(%d*)_?(%w*)'
local function parse_result(args)
local result = {
name = args['result'],
count = tonumber(args['result_count'] or args['result_amount'] or args['result_quantity'] or args['result_qty']) or 1
}
if args['result_display'] then
result.display = args['result_display']
else
result.display = result.name
end
return result
end
local function parse_ingredients(args)
local ingredients = {}
for k, v in pairs(args) do
local ing_index, ing_prop = string.match(k, INGREDIENT_KEY_PATTERN)
if ing_index then
ing_index = tonumber(ing_index) or 1
if not ingredients[ing_index] then
ingredients[ing_index] = {
count = 1
}
end
local ingredient = ingredients[ing_index]
if ing_prop == "" then
ingredient.name = v
if not ingredient.display then ingredient.display = v end
elseif ing_prop == "count" or ing_prop == "amount" or ing_prop == "quantity" or ing_prop == "qty" then
ingredient.count = tonumber(v) or 1
elseif ing_prop == "display" then
ingredient.display = v
end
end
end
return ingredients
end
local function parse_type(args)
if not args['type'] then return 'crafting' end
local i_type = string.lower(tostring(args['type']))
if string.match(i_type, '^manufactur') then
return 'manufacturing'
end
return 'crafting'
end
local function make_quantity(quantity)
return html.create('td')
:addClass('quantity')
:wikitext(quantity or 1)
end
local p = {}
function p.main(frame)
local args = getArgs(frame)
return p._main(args)
end
function p._main(args)
local result = parse_result(args)
local ingredients = parse_ingredients(args)
local r_type = parse_type(args)
local ingredient_count = #ingredients
local result_cell = html.create('td')
:attr('rowspan', ingredient_count)
:wikitext(string.format("[[%s|%s]]", result.name, result.display))
local type_link
if r_type == "crafting" then
type_link = "[[Crafting]]"
else
type_link = "[[Manufacturing]]"
end
local type_cell = html.create('td'):attr('rowspan', ingredient_count):wikitext(type_link)
local firstRow = html.create('tr')
local rows = { firstRow }
for i, ingredient in ipairs(ingredients) do
local td = html.create('td')
:wikitext(string.format("[[%s|%s]]", ingredient.name, ingredient.display))
if i == 1 then
firstRow:node(td)
firstRow:node(make_quantity(ingredient.count))
else
local row = html.create('tr')
:node(td)
:node(make_quantity(ingredient.count))
rows[#rows + 1] = row
end
end
firstRow
:node(result_cell)
:node(make_quantity(result.count):attr('rowspan', ingredient_count))
:node(type_cell)
local tbody = html.create('tbody')
for _, row in ipairs(rows) do
tbody:node(row)
end
local thead = html.create('thead')
:tag('tr')
:tag('th'):attr('colspan', 2):wikitext('Ingredients'):done()
:tag('th'):attr('colspan', 2):wikitext('Result'):done()
:tag('th'):attr('rowspan', 2):wikitext('Type'):done()
:done()
:tag('tr')
:tag('th'):wikitext('Item'):done()
:tag('th')
:tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done()
:done()
:tag('th'):wikitext('Item'):done()
:tag('th')
:tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done()
:done()
:allDone()
local tbl = html.create('table')
:addClass('wikitable')
:addClass('recipe')
:node(thead)
:node(tbody)
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Recipe/styles.css' }
} .. tostring(tbl)
end
return p
a728b87a48a6e8450149103101c31566087d1935
1528
1527
2025-09-08T15:41:29Z
Sharparam
284703
Fix weird table render bug
Scribunto
text/plain
local html = mw.html
local getArgs = require('Module:Arguments').getArgs
local INGREDIENT_KEY_PATTERN = '^ingredient(%d*)_?(%w*)'
local function parse_result(args)
local result = {
name = args['result'],
count = tonumber(args['result_count'] or args['result_amount'] or args['result_quantity'] or args['result_qty']) or 1
}
if args['result_display'] then
result.display = args['result_display']
else
result.display = result.name
end
return result
end
local function parse_ingredients(args)
local ingredients = {}
for k, v in pairs(args) do
local ing_index, ing_prop = string.match(k, INGREDIENT_KEY_PATTERN)
if ing_index then
ing_index = tonumber(ing_index) or 1
if not ingredients[ing_index] then
ingredients[ing_index] = {
count = 1
}
end
local ingredient = ingredients[ing_index]
if ing_prop == "" then
ingredient.name = v
if not ingredient.display then ingredient.display = v end
elseif ing_prop == "count" or ing_prop == "amount" or ing_prop == "quantity" or ing_prop == "qty" then
ingredient.count = tonumber(v) or 1
elseif ing_prop == "display" then
ingredient.display = v
end
end
end
return ingredients
end
local function parse_type(args)
if not args['type'] then return 'crafting' end
local i_type = string.lower(tostring(args['type']))
if string.match(i_type, '^manufactur') then
return 'manufacturing'
end
return 'crafting'
end
local function make_quantity(quantity)
return html.create('td')
:addClass('quantity')
:wikitext(quantity or 1)
end
local p = {}
function p.main(frame)
local args = getArgs(frame)
return p._main(args)
end
function p._main(args)
local result = parse_result(args)
local ingredients = parse_ingredients(args)
local r_type = parse_type(args)
local ingredient_count = #ingredients
local result_cell = html.create('td')
:attr('rowspan', ingredient_count)
:wikitext(string.format("[[%s|%s]]", result.name, result.display))
local type_link
if r_type == "crafting" then
type_link = "[[Crafting]]"
else
type_link = "[[Manufacturing]]"
end
local type_cell = html.create('td'):attr('rowspan', ingredient_count):wikitext(type_link)
local firstRow = html.create('tr')
local rows = { firstRow }
for i, ingredient in ipairs(ingredients) do
local td = html.create('td')
:wikitext(string.format("[[%s|%s]]", ingredient.name, ingredient.display))
if i == 1 then
firstRow:node(td)
firstRow:node(make_quantity(ingredient.count))
else
local row = html.create('tr')
:node(td)
:node(make_quantity(ingredient.count))
rows[#rows + 1] = row
end
end
firstRow
:node(result_cell)
:node(make_quantity(result.count):attr('rowspan', ingredient_count))
:node(type_cell)
local tbl = html.create('table')
:addClass('wikitable')
:addClass('recipe')
:tag('tr')
:tag('th'):attr('colspan', 2):wikitext('Ingredients'):done()
:tag('th'):attr('colspan', 2):wikitext('Result'):done()
:tag('th'):attr('rowspan', 2):wikitext('Type'):done()
:done()
:tag('tr')
:tag('th'):wikitext('Item'):done()
:tag('th')
:tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done()
:done()
:tag('th'):wikitext('Item'):done()
:tag('th')
:tag('abbr'):attr('title', 'Quantity'):wikitext('Qty'):done()
:done()
:done()
for _, row in ipairs(rows) do
tbl:node(row)
end
return mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Recipe/styles.css' }
} .. tostring(tbl)
end
return p
65eb71beee89a329f11e0315759e7fa99d0ae2d2
Module:Recipe/doc
828
917
1522
2025-09-08T15:22:16Z
Sharparam
284703
Created page with "This module should not be used directly, instead use it via the {{tl|Recipe}} template. == Styles == * [[Module:Recipe/styles.css]] == Test cases == === Simple single ingredient recipe === <syntaxhighlight lang="wikitext"> {{#invoke:Recipe|main |result = Copper Ingot |ingredient = Copper Ore }} </syntaxhighlight> {{#invoke:Recipe|main |result = Copper Ingot |ingredient = Copper Ore }} === Multiple ingredients === <syntaxhighlight lang="wikitext"> {{#invoke:Recipe|ma..."
wikitext
text/x-wiki
This module should not be used directly, instead use it via the {{tl|Recipe}} template.
== Styles ==
* [[Module:Recipe/styles.css]]
== Test cases ==
=== Simple single ingredient recipe ===
<syntaxhighlight lang="wikitext">
{{#invoke:Recipe|main
|result = Copper Ingot
|ingredient = Copper Ore
}}
</syntaxhighlight>
{{#invoke:Recipe|main
|result = Copper Ingot
|ingredient = Copper Ore
}}
=== Multiple ingredients ===
<syntaxhighlight lang="wikitext">
{{#invoke:Recipe|main
|result = Big Item
|ingredient1 = Small Item
|ingredient2 = Medium Item
}}
</syntaxhighlight>
{{#invoke:Recipe|main
|result = Big Item
|ingredient1 = Small Item
|ingredient2 = Medium Item
}}
<includeonly>{{Sandbox other||[[Category:Module]]}}</includeonly><!--
--><noinclude>[[Category:Module documentation pages]]</noinclude>
924dabd9b5ce88588b5468b5e3a7e93320fff6df
1526
1522
2025-09-08T15:30:04Z
Sharparam
284703
Fix category
wikitext
text/x-wiki
This module should not be used directly, instead use it via the {{tl|Recipe}} template.
== Styles ==
* [[Module:Recipe/styles.css]]
== Test cases ==
=== Simple single ingredient recipe ===
<syntaxhighlight lang="wikitext">
{{#invoke:Recipe|main
|result = Copper Ingot
|ingredient = Copper Ore
}}
</syntaxhighlight>
{{#invoke:Recipe|main
|result = Copper Ingot
|ingredient = Copper Ore
}}
=== Multiple ingredients ===
<syntaxhighlight lang="wikitext">
{{#invoke:Recipe|main
|result = Big Item
|ingredient1 = Small Item
|ingredient2 = Medium Item
}}
</syntaxhighlight>
{{#invoke:Recipe|main
|result = Big Item
|ingredient1 = Small Item
|ingredient2 = Medium Item
}}
<includeonly>{{Sandbox other||[[Category:Modules]]}}</includeonly><!--
--><noinclude>[[Category:Module documentation pages]]</noinclude>
282fd35889589b1a3259a62fa0b2a439cf3ac551
Module:Recipe/styles.css
828
918
1523
2025-09-08T15:22:41Z
Sharparam
284703
Created page with "table.recipe td.quantity { text-align: right; }"
sanitized-css
text/css
table.recipe td.quantity {
text-align: right;
}
6c91e0a24445782d77a41927c93fcea5e8999f01
Template:Recipe
10
919
1529
2025-09-08T15:42:17Z
Sharparam
284703
Created page with "<includeonly>{{#invoke:Recipe|main}}</includeonly><!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
<includeonly>{{#invoke:Recipe|main}}</includeonly><!--
--><noinclude>{{Documentation}}</noinclude>
60f7d633c7b254e0cc19de5121aa901700e7462e
Template:Recipe/doc
10
920
1530
2025-09-08T15:46:24Z
Sharparam
284703
Created page with "== Examples == === Simple recipe with single ingredient === <syntaxhighlight lang="wikitext"> {{Recipe | result = Copper Ingot | ingredient = Copper Ore }} </syntaxhighlight> {{Recipe | result = Copper Ingot | ingredient = Copper Ore }} === Multiple ingredients === <syntaxhighlight lang="wikitext"> {{Recipe | result = Potion | ingredient1 = Water | ingredient2 = Flask }} </syntaxhighlight> {{Recipe | result = Potion | ingredient1 = Water | ingredient2 = Flask }} ===..."
wikitext
text/x-wiki
== Examples ==
=== Simple recipe with single ingredient ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Copper Ingot
| ingredient = Copper Ore
}}
</syntaxhighlight>
{{Recipe
| result = Copper Ingot
| ingredient = Copper Ore
}}
=== Multiple ingredients ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Potion
| ingredient1 = Water
| ingredient2 = Flask
}}
</syntaxhighlight>
{{Recipe
| result = Potion
| ingredient1 = Water
| ingredient2 = Flask
}}
=== Manufacturing recipe ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Fancy Stone
| ingredient = Regular Stone
| type = manufacturing
}}
</syntaxhighlight>
{{Recipe
| result = Fancy Stone
| ingredient = Regular Stone
| type = manufacturing
}}
=== Quantities ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Arrow
| result_quantity = 10
| ingredient1 = Stone
| ingredient1_quantity = 5
| ingredient2 = Wood
| ingredient2_quantity = 2
| ingredient3 = Feather
| ingredient3_quantity = 10
| type = crafting
}}
</syntaxhighlight>
{{Recipe
| result = Arrow
| result_quantity = 10
| ingredient1 = Stone
| ingredient1_quantity = 5
| ingredient2 = Wood
| ingredient2_quantity = 2
| ingredient3 = Feather
| ingredient3_quantity = 10
| type = crafting
}}
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
9217aa42d53ccd4fcdb294788416035335932bce
Hellicar's Maxims
0
379
1531
521
2025-09-12T21:28:51Z
Sharparam
284703
Add contents of the documents
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[lore]] [[documents]] that can be found in {{BFF}}.
== Overview ==
There are 3 parts to collect in the game.
{{Quote
|title=1/3
|If it should happen that you fell lost, turn right at the first gate and start again. Don't hesitate. What has been will always be. What is to come was never ours. The orchid has blossomed at exactly the same spot every year, so far, but, that is no guarantee. It might not make it back this year. The skywhales might lose their way in the swaying winds – the swallows never make it back home. We do not know. And in that lies the power of all the things that might be. The map grows old instantly, getting out of the same side of the bed tiresome. The almond's blossom often comes too soon. It is just stubborn determination. The walls of the Megalopolis were not designed to fall. The Angel thought this message would for ever last. Times is not carved out in a straight line. She is like the waves and fickle as the clouds. She comes, she goes, she weaves. If lost, it might not be a gate, but turn left again at the first sign. Turn and remain on the narrow and the straight.
}}
{{Quote
|title=2/3
|These are simply lives, with all their mechanisms and internal complexity, their mythology and their aspirations. Each flame a fire, each fire a small world as infinite as the imagination, as deep as the mesmerising sea. On the surface we are listening to the wind, the gentle ripples following on as waves, the clouds hovering with subtle menace, filled with intangible dimensions. There are few trees on the coast, struggling against the salty spray, growing with dogged determination. Their blossom is feeble. Their fruit bitter. Their leaves hard and brittle. The frost doesn't come as far as the coast. The snow is a vision and the bitter bite of the steady breeze that does feed the fire, that does reach down and nourish the soul. Simply lives within which a unique concoction of the very same days provide a million varied flavours. The ghosts are inhabitants of the past, the sky eels carry the ragged dreams of battles that are still to come. Leaves that fell from a tree, drops that left the ocean.
}}
{{Quote
|title=3/3
|The picture is tattered, taunted and all but torn. The sun struggles to deal with this particular dawn. It is early and it is still late. The clouds have formed, the rain beats a gentle rhythm in the glistening street. Water and oil, the rainbow bled into the ground. The light came and went, the land was savagely raped and the hills were gutted so that we might have slightly better lives. Paint a scene where the kestrel still hovers. Paint a scene where we might see what we have and what had once been.
}}
== Acquisition ==
Drops from [[enemies]] in the game.
* Asylum enemy with cape and sword+shield.
{{Navbox/Documents}}
[[Category:Lore]]
[[Category:Documents]]
b776e2d8e1d9c8c96e6aff603d38f0bdb6792bcc
Konrad's War Log
0
921
1532
2025-09-12T21:39:23Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a collection of [[Documents|lore documents]] that can be found in {{BFF}}. == Overview == There are 5 different logs to collect. Based on the name and contents of the final log, it can be assumed that [[Konrad the Traitor]] is the author of these logs. {{Quote |title=1/5 |The first phase is complete and the transit points have been secured. The population is cooperative, so I have ensured the men keep their calm. There is talk of some kind of co..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a collection of [[Documents|lore documents]] that can be found in {{BFF}}.
== Overview ==
There are 5 different logs to collect.
Based on the name and contents of the final log, it can be assumed that [[Konrad the Traitor]] is the author of these logs.
{{Quote
|title=1/5
|The first phase is complete and the transit points have been secured. The population is cooperative, so I have ensured the men keep their calm. There is talk of some kind of corruption at play, but all I can make out for now is that the citizens blame each other for everything, competing to show their loyalty to our presence.
Annoying.
}}
{{Quote
|title=2/5
|We now know the location of [[The Serdars|the Serdars]]. I was hoping for a reply from [[Yaroslav]], but the first dispatch hasn't returned. I am now sending another and reattempting the completion of the second phase. We've only arrived but the locals already tire me. So does the weather, if it can even be called that – the sky and the rain feel as if they are all the exhaust material of some unbearable manufacturing zone.
}}
{{Quote
|title=3/5
|Negotiations have failed, the second phase is now obsolete and three of our platoons have been obliterated by the Serdars. Yarsoslav has, I believe, gone mad. This was his army just as much as mine until this mess. I will never understand what leads others to betrayal… He butchered our men as if he never knew them. NOTE: I suspect [[The Administration|the Administration]] is also establishing their presence here.
}}
{{Quote
|title=4/5
|The citizens are at moments unmanageable, at others, docile and apathetic. As for us, I can no longer afford any expeditions below since I have only a few men remaining. Two full divisions are on their way for support, since news of our debacle at the gate has spread – I am afraid it is open war with the Serdars… There will be no easy resolution to whatever's going on. If only I could have a word with Yaroslav myself, I'm sure he would see reason.
}}
{{Quote
|title=5/5
|We were ambushed yesterday in the temple we've set up camp in – yet it feels pathetic to say by whom. A single knight, wearing the grin of death! He would pass for a clown if he hadn't told me what he had. I will retire into what's left of the monastery to reconsider everything. The state of affairs is such that I'm sure the administration will soon step in. I would wish luck if it were anyone else venturing below, but I hope they meet what they deserve at Yaroslav's gate.
}}
{{Navbox/Documents}}
[[Category:Documents]]
d27a842a52d1cf714c1c4ced79de13cb39e49d8f
Helena's Diary Fragment
0
922
1533
2025-09-12T21:49:39Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a collection of [[Documents|lore documents]] in {{BFF}}. == Overview == There are 5 fragments in the game. {{Quote |title=1/5 |When they arrived, they said they were looking for a traitor and those who betrayed them… Maybe the soldiers who came before? Still, I was curious about the new one… he was taller than all the soldiers he came with. He seemed handsome and his name sounded noble… [[Konrad the Traitor|Konrad]]. His men lost their way..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a collection of [[Documents|lore documents]] in {{BFF}}.
== Overview ==
There are 5 fragments in the game.
{{Quote
|title=1/5
|When they arrived, they said they were looking for a traitor and those who betrayed them… Maybe the soldiers who came before? Still, I was curious about the new one… he was taller than all the soldiers he came with. He seemed handsome and his name sounded noble… [[Konrad the Traitor|Konrad]]. His men lost their way when the strange knight with a face like a skull{{note|Likely the [[Skull Knight]].}} joined them in their temple… A fight broke out and all we could hear was the slaughter inside. Konrad survived and left then but something was strange. I wonder where he is. I don't even know him but I hope he's alive and well.
}}
{{Quote
|title=2/5
|Things were becoming more chaotic and if that wasn't enough, more soldiers arrived. These were not only looking for their rebel, but they also seemed to be obsessing over the area beyond the [[Machinarium]], just like the ones Konrad was looking for. Soon, even more of them showed up and they were the exact opposite of what Konrad was like. Big bulks of metal, bald and brutal. They seemed to lose track of the time just like the rest of us though and when they lost their patience… some things are best left unsaid.
}}
{{Quote
|title=3/5
|We were given shovels to clean the neighborhood and pile everything up… the rubble and the dead in their containers. We then moved this to a nearby site where other piles were being incinerated. As I did what I was told, I felt like I had so many narrow escapes. Every thread to my life seemed to boost my eagerness to survive. Things lose sense by the day and this confusion seems to be crippling the invaders as well. I hope we can find a way to leave soon so we can just put all of this behind us.
}}
{{Quote
|title=4/5
|Just when I thought things couldn't get any worse, they brought their monks and scribes. Words cannot describe what's going on. One moment they completely stomp out the people from a certain building, the next, it's as if the building has been abandoned for… decades? And then later in the week, the lights in it go on. I swear I saw someone looking out at me from inside one night.
}}
{{Quote
|title=5/5
|The person in the window waved at me again last night. Maybe it's someone they spared during the raid? My ex secretary says the days now overlap. Yesterday feels like tomorrow, and now feels like something that happened a week ago. Perhaps all the things [[Feigenbaum]] played with are finally catching up with us. The hunger however is now the only thing we worry about.
}}
== Notes ==
{{Notelist}}
{{Navbox/Documents}}
[[Category:Documents]]
9b300b89df13f885be3a2cb1187586cd95148ebc
Guiscard's Manifest
0
923
1534
2025-09-12T21:56:18Z
Sharparam
284703
Created page with "'''{{PAGENAME}}''' is a collection of [[Documents|lore documents]] in {{BFF}}. == Overview == There are 3 parts in the game. {{Quote |title=1/3 |Those surrounded by comfort wallow in excesses, disturbed only by the most accidental of anxieties until an event such as this – and once that opulence comes into jeopardy, other extremes become priorities – flight, retaining all that was accumulated on the backs of others and if necessary, the instant siding with the inv..."
wikitext
text/x-wiki
'''{{PAGENAME}}''' is a collection of [[Documents|lore documents]] in {{BFF}}.
== Overview ==
There are 3 parts in the game.
{{Quote
|title=1/3
|Those surrounded by comfort wallow in excesses, disturbed only by the most accidental of anxieties until an event such as this – and once that opulence comes into jeopardy, other extremes become priorities – flight, retaining all that was accumulated on the backs of others and if necessary, the instant siding with the invader, to keep the honey flowing. Existence at one point becomes only the pursuit of more.
}}
{{Quote
|title=2/3
|Those however who are in general condemned to suffer, who struggle even in times that are deemed good for others, must again rely on numbness and intoxication to see through it all. These unfortunate misers, used to being accused by the previously described for everything and anything, then fall even lower, to the level of blaming each other for how things have turned out instead of the foreign enemy or their previous rulers – and when that is done, they go even lower. Where they will once again kneel and obey, for a dog may have a preference for one master over another, but his base loyalty can always be bought with the promise of mere survival.
}}
{{Quote
|title=3/3
|To be a hunter, a whaler, an officer, or a doctor, and to remain so only to not lose one's livelihood. We should strive however for an era in which none of us have exclusive spheres of activity, where each can become accomplished in any branch one wishes, and where the polis regulates the excesses of necessity, thus making it possible to do one thing today and another tomorrow – to hunt in the morning, to sail in the afternoon, to administrate accordingly in the evening, heal and nurture after dinner, without ever having to confine one to the base rules of surviving – but to strive for a life filled with the blossoms of labor and inspiration.
}}
{{Navbox/Documents}}
[[Category:Documents]]
3a9e9b2b4ef93abeb51e38c0a90a4dfbe0496cab
Monastery Observation
0
924
1535
2025-09-12T22:01:55Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] that can be found in [[Monastery|the Monastery]] in {{BFF}}. == Overview == {{Quote |Standing at the top of the cliff, a derelict monastery. An anachronistic island in a sea of decaying technology. The surrounding residential structure looms oppressively, its vast expanse of concrete and rusted metal interwoven with a labyrinth of cables. Everything is draped in a strange, sickly moss. An eerie silence h..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] that can be found in [[Monastery|the Monastery]] in {{BFF}}.
== Overview ==
{{Quote
|Standing at the top of the cliff, a derelict monastery. An anachronistic island in a sea of decaying technology. The surrounding residential structure looms oppressively, its vast expanse of concrete and rusted metal interwoven with a labyrinth of cables. Everything is draped in a strange, sickly moss. An eerie silence hung in the air, broken only by the distant hum of [[The Megastructure|the megastructure]]. The moss, with its unsettling, almost sentient presence, clung to the remnants of the past, casting a malign shadow over this forgotten place. Each step towards the monastery feels like a descent into madness, the boundaries between the organic and the artificial blurring in the twilight of a world long caving in on itself. It's hard to tell what belongs to what time any more. The only compass here is the pull of the anomaly's core.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
4fc50ecb141e32b0853c77bcbfcb45b95e8de097
Monastery Impression
0
370
1536
503
2025-09-12T22:02:24Z
Sharparam
284703
Add needs location template
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] that can be found at [[Monastery|the Monastery]] in {{BFF}}.
== Overview ==
{{Quote
| Venturing into the anomalous zone at the edge of this crumbling colony, I was enveloped by a world devoid of sense, dominated by the cold, relentless sprawl of concrete and rebar. Rusted metal carcasses of buildings stood as grim monuments to a forgotten era, their skeletal frames interwoven with the vestiges of ancient technology and tangled cables that snaked across the ground like decaying veins. The omnipresent drone of [[Omnistructure|the structure]] reverberated through the air, a constant reminder of its oppressive presence – here, louder than anywhere before. As I picked my way through the debris, I could sense the weight of the past pressing in, the technological remnants whispering secrets of a world that once thrived but now lay silent and corroded.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
e49ac2d8ade62fa55c9473f1cf8f9d220a49aece
Dreadguard (data log)
0
925
1537
2025-09-12T22:05:30Z
Sharparam
284703
Created page with "{{Needs location}} '''Dreadguard''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |What are these [[Dreadguard (NPC)|]] made of… not a flinch, not a single discernable sign of discomfort. I know their training is gruelling, but this level of fortitude goes beyond anything I've seen. }} == See also == * [[Dreadguard (NPC)]] * [[Dreadguard (enemy)]] {{Navbox/Data logs}} [[Category:Data logs]]"
wikitext
text/x-wiki
{{Needs location}}
'''Dreadguard''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|What are these [[Dreadguard (NPC)|Dreadguard]] made of… not a flinch, not a single discernable sign of discomfort. I know their training is gruelling, but this level of fortitude goes beyond anything I've seen.
}}
== See also ==
* [[Dreadguard (NPC)]]
* [[Dreadguard (enemy)]]
{{Navbox/Data logs}}
[[Category:Data logs]]
b7524b233cab17929408120d64a1f2e17254b1d0
Template:Navbox/Data logs
10
290
1538
367
2025-09-12T22:05:55Z
Sharparam
284703
Fix link to dreadguard data log
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard (data log)|Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[A Broken Reality]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[Understanding]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
3cfff727c61ad5d8c3fb1dab5f8cd372909c1190
Inquisitors
0
926
1539
2025-09-12T22:08:04Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |I know [[The Inquisition|the Inquisition]] is fanatical. It seems their way of dealing with this crippling atmosphere is by embracing and revelling in it. In their body language, you can tell they find enjoyment in this. They know they are meant to be here, they know they are witnessing a miracle. They perceive all adversity as a symptom of their growing faith. }} {{N..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|I know [[The Inquisition|the Inquisition]] is fanatical. It seems their way of dealing with this crippling atmosphere is by embracing and revelling in it. In their body language, you can tell they find enjoyment in this. They know they are meant to be here, they know they are witnessing a miracle. They perceive all adversity as a symptom of their growing faith.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
519fb60a07fc00c20d825353d3badb1ed4d4de7c
Eternal Rain
0
927
1540
2025-09-12T22:09:22Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |The rain here is calming. The noise drowns everything else out. The creaking and humming of the grating concrete and rebar are all drowned out by the shattering of raindrops. Maybe one could dream here. }} {{Navbox/Data logs}} [[Category:Data logs]]"
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|The rain here is calming. The noise drowns everything else out. The creaking and humming of the grating concrete and rebar are all drowned out by the shattering of raindrops. Maybe one could dream here.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
b69b9bc7af3a2e0771d51d611cec3e7210104bd4
Habitation
0
928
1541
2025-09-12T22:11:16Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |This must have been intended as a densely populated area – probably for a lower social class. But there is a certain charm in the crammed alleyways and staircases leading from one potential life to another. Lives piled one on top of another. Lives affecting one another. In other places of [[The Omnistructure|the structure]] you'd be lucky to see another person in mon..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|This must have been intended as a densely populated area – probably for a lower social class. But there is a certain charm in the crammed alleyways and staircases leading from one potential life to another. Lives piled one on top of another. Lives affecting one another. In other places of [[The Omnistructure|the structure]] you'd be lucky to see another person in months… sometimes years…
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
1fb43ef211ccc8342b0c2e3a86088189bda2da0e
Industrial Silence
0
929
1542
2025-09-12T22:13:07Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |The landscape here is dominated by industrial remnants and utilitarian constructions. Scaffolding from long-abandoned projects entwines with the silhouettes of heavy machinery, their rusting forms standing as silent sentinels to a bygone era. The structures, though now dilapidated, suggest a time when this place might have been vibrant and bustling. The structure here..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|The landscape here is dominated by industrial remnants and utilitarian constructions. Scaffolding from long-abandoned projects entwines with the silhouettes of heavy machinery, their rusting forms standing as silent sentinels to a bygone era. The structures, though now dilapidated, suggest a time when this place might have been vibrant and bustling. The structure here must be rather old, no signs of builders influencing the landscape. Once, perhaps, this locale could have been a harmonious blend of functionality and beauty.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
333247b7debd32368f96fce2d4312eb6e1db7d56
Encrypted Radiation
0
930
1543
2025-09-12T22:14:46Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |Though the content remains entirely indiscernible, analysis of the radiation suggested something. The knight's presence was a haunting mix of foreboding and sorrow, as if it bore a dire message wrapped in deep remorse. Its spectral form pulsed with this eerie energy, leaving an unsettling impression of a warning long past and a sorrowful history best heeded. }} {{Navb..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|Though the content remains entirely indiscernible, analysis of the radiation suggested something. The knight's presence was a haunting mix of foreboding and sorrow, as if it bore a dire message wrapped in deep remorse. Its spectral form pulsed with this eerie energy, leaving an unsettling impression of a warning long past and a sorrowful history best heeded.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
7143dc61895b739ecf8bcd40508983b342642832
The Deep Monastery
0
931
1544
2025-09-12T22:19:29Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |In the heart of [[Desert|the desert]], beneath the oppressive mist, stands an enormous, abandoned monastery, its once-grand structure now weathered and eroded by the relentless sands. Behind it, a vast and malignant labyrinth emerges from [[Anomaly|the anomaly]], a chaotic expanse where time and space are distorted beyond recognition. Straight lines no longer align; th..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|In the heart of [[Desert|the desert]], beneath the oppressive mist, stands an enormous, abandoned monastery, its once-grand structure now weathered and eroded by the relentless sands. Behind it, a vast and malignant labyrinth emerges from [[Anomaly|the anomaly]], a chaotic expanse where time and space are distorted beyond recognition. Straight lines no longer align; they twist and bend unpredictably. Matter here perpetually dissipates and crumbles, never quite vanishing, as if the space is caught in a continuous loop of decay. The immense radiation and the absence of any sense of causality render this environment inhospitable to most. The very fabric of reality seems to fracture, making survival impossible for all but the most resilient. Despite the inhospitable conditions, rumours persist of a handful of [[The Serdars|Serdars]] who have taken refuge in the monastery, braving the inhospitable surroundings and the malignant influence of the labyrinth.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
5f322820627894b90b0726ad7d1db3a7837028e7
Monolith
0
932
1545
2025-09-12T22:21:33Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |They say that deep within [[Desert|the desert]], there's an ancient, abandoned monastery standing solitary against the endless sands. The radiation there must be incomprehensible. No one could survive such an environment—any conscious mind would break apart instantly. Yet, whispers from those who dare to speak of it claim that [[the Serdars]], have somehow establishe..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|They say that deep within [[Desert|the desert]], there's an ancient, abandoned monastery standing solitary against the endless sands. The radiation there must be incomprehensible. No one could survive such an environment—any conscious mind would break apart instantly. Yet, whispers from those who dare to speak of it claim that [[the Serdars]], have somehow established a hold within the monastery.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
f80c637c7c0ac8d044f63faa9384b10008bc943d
Desert Whispers
0
933
1546
2025-09-12T22:25:42Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |Whispers from [[Desert|the desert]] say that [[Yaroslav|Jaroslav]]{{sic|nolink=y}} has sent a chilling message to anyone venturing towards their domain. The message warns that anyone who dares march into the desert will confront their destiny amidst the ruins. Jaroslav's{{sic|nolink=y}} words are shrouded in dark foreboding, suggesting that the desert itself is a cruci..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|Whispers from [[Desert|the desert]] say that [[Yaroslav|Jaroslav]]{{sic|nolink=y}} has sent a chilling message to anyone venturing towards their domain. The message warns that anyone who dares march into the desert will confront their destiny amidst the ruins. Jaroslav's{{sic|nolink=y}} words are shrouded in dark foreboding, suggesting that the desert itself is a crucible of fate, where every step taken will lead to a reckoning with one's deepest fears and ultimate destiny. [[The Serdars]], it seems, have embraced the harsh, twisted reality of their environment, and their leader's message serves as a grim invitation to face the inexorable truth that awaits in the forsaken sands. They say the Serdar have turned against [[The Empire|the empire]].
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
83287ab7c0a22abdb169ed7e3d8de3d6c1edc9aa
Asylum (data log)
0
934
1547
2025-09-12T22:29:51Z
Sharparam
284703
Created page with "{{Needs location}} '''Asylum''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |The night at [[Asylum|the asylum]] is suffused with an oppressive darkness, where shadows dance ominously across the walls of the forsaken facility. Within these grim corridors, the absence of any ethical code has allowed for the most abominable experiments on living creatures, their suffering amplified by the cold, indifferent machinery of the asylum. The air is thick with..."
wikitext
text/x-wiki
{{Needs location}}
'''Asylum''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|The night at [[Asylum|the asylum]] is suffused with an oppressive darkness, where shadows dance ominously across the walls of the forsaken facility. Within these grim corridors, the absence of any ethical code has allowed for the most abominable experiments on living creatures, their suffering amplified by the cold, indifferent machinery of the asylum. The air is thick with the stench of decay and chemical solvents, a nauseating mix that clings to everything. Dim, flickering lights reveal ghastly scenes—mangled forms and twisted apparatuses allude to a grotesque pursuit – it is unclear what is being pursued though. The asylum's eerie quiet is occasionally broken by the muffled cries and the dissonant hum of the experiments – either long past or yet to be conducted. The very essence of humanity seems to have been sacrificed here, replaced by a relentless drive for knowledge beyond what we should be allowed to know.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
25ce1dd3a390767e876067d62f9f773a38ccfde2
Terror
0
935
1548
2025-09-12T22:32:38Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |[[Asylum|The asylum's]] once sterile operating theaters now bear witness to grotesque amalgamations of flesh and metal, as madness seeks to forge a perverse harmony through unholy means. The stench of decay and chemicals pervades every corner, mingling with the metallic tang of blood and the acrid odor of fear. Amidst the flickering lights and shadowed corners, whisper..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|[[Asylum|The asylum's]] once sterile operating theaters now bear witness to grotesque amalgamations of flesh and metal, as madness seeks to forge a perverse harmony through unholy means. The stench of decay and chemicals pervades every corner, mingling with the metallic tang of blood and the acrid odor of fear. Amidst the flickering lights and shadowed corners, whispers speak of a deranged pursuit—an obsession with unlocking a cosmic order through abominable acts, where ethics have long been abandoned in favor of a twisted vision of divine symmetry. It's hard to tell who is more mad. The conductors or the patients. In some sense here, there is an achieved symmetry – a symmetry of torture.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
951bf305af5e8bd9414682762c5b55873b8c470a
The Deep
0
936
1549
2025-09-12T22:35:32Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |Concrete and steel rise in chaotic, dream-like silhouettes, their shapes both unsettling an oddly familiar, as if shadows themselves have taken on a sapient quality. The buildings, though solid and tangible, have an otherworldly quality, reminiscent of fleeting dreams made manifest. Each structure seems to be a fragment of a once-ethereal vision, now crystallized into..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|Concrete and steel rise in chaotic, dream-like silhouettes, their shapes both unsettling an oddly familiar, as if shadows themselves have taken on a sapient quality. The buildings, though solid and tangible, have an otherworldly quality, reminiscent of fleeting dreams made manifest. Each structure seems to be a fragment of a once-ethereal vision, now crystallized into grim, imposing shapes that loom in the perpetual twilight. The city is an eerie, tangible manifestation of shadows given form, embodying the eerie, disjointed nature of dreams that have seeped down from above and coalesced into a haunting, shadowy reality.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
2b8e4ee804705036e23de0293db9889a9a6a77e4
A Vision
0
937
1550
2025-09-12T22:37:30Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |This place, a sprawling labyrinth of vast concrete walls and tangled cables, swallows everything that enters its grasp. Those who are consumed by the city are not lost to oblivion; instead, they linger as perpetual echoes, their shadows etched into the cold, unfeeling concrete. The walls themselves seem alive with these ghostly traces, their forms distorted and eternal..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|This place, a sprawling labyrinth of vast concrete walls and tangled cables, swallows everything that enters its grasp. Those who are consumed by the city are not lost to oblivion; instead, they linger as perpetual echoes, their shadows etched into the cold, unfeeling concrete. The walls themselves seem alive with these ghostly traces, their forms distorted and eternal, a testament to lives that have been frozen in an unending state of limbo.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
8afecad3b45807c4c24b4e7b9f0d503e324a5e2a
The Drone
0
938
1551
2025-09-12T22:40:09Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |The city's hum is a relentless, grating sound, a discordant symphony that combines the despair of lives eternally trapped and the unfulfilled potential of what could have been. It resonates through the city's structures, a reminder of the tragedy that has befallen it. The once-vibrant reality has calcified into a grotesque parody of itself, consumed by its own anomalou..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|The city's hum is a relentless, grating sound, a discordant symphony that combines the despair of lives eternally trapped and the unfulfilled potential of what could have been. It resonates through the city's structures, a reminder of the tragedy that has befallen it. The once-vibrant reality has calcified into a grotesque parody of itself, consumed by its own anomalous nature. The city's sapience, once a thriving essence of life and purpose, has been devoured by its own insatiable hunger, leaving behind only a haunting echo of what was lost. This relentless consumption has turned the city into a monument to its own tragedy, a place where sense and meaning have been irretrievably lost to the void.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
6b3bff6e46a7f7fc8d1d47dcca48ad3d1eec976d
Inhabitants
0
381
1552
1428
2025-09-12T22:40:42Z
Sharparam
284703
Use needs location template instead of stub + needs coords
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] [[lore]] [[Items|item]] found in {{BFF}}.
== Overview ==
{{Quote
|The inhabitants, if they can be called that, move through their days in a trance-like manner, their actions governed by the city's oppressive rhythm rather than any discernible purpose. They drift through the shadowy streets, their forms often indistinguishable from the pervasive gloom that surrounds them. Their movements are slow and deliberate, almost mechanical, as if each step is taken in reluctant compliance with an unseen force.
}}
{{Navbox/Data logs}}
[[Category:Lore]]
[[Category:Data logs]]
99696204437b9f93e7efbd49bfdb4e5de2a6a8dc
Calcified Lives
0
939
1553
2025-09-12T22:42:38Z
Sharparam
284703
Created page with "{{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |Many citizens have succumbed to a final, calcified state, their fates sealed in a claustrophobic stillness. These figures are trapped in a low-energy existence, frozen in the midst of their routines. Their forms are rigid and unchanging, as if the very essence of their being has been petrified by the oppressive atmosphere. Some of them, seemingly in a state of worship..."
wikitext
text/x-wiki
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|Many citizens have succumbed to a final, calcified state, their fates sealed in a claustrophobic stillness. These figures are trapped in a low-energy existence, frozen in the midst of their routines. Their forms are rigid and unchanging, as if the very essence of their being has been petrified by the oppressive atmosphere. Some of them, seemingly in a state of worship – or delirium, towards eternal nothingness.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
6fe361733296ddf87d7856d8925b22c10a94bd42
Manta Rays (data log)
0
940
1554
2025-09-12T22:45:19Z
Sharparam
284703
Created page with "{{Needs location}} '''Manta Rays''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |Immense flying manta rays drift silently through the shadowed expanse, their presence both mesmerizing and unsettling. These creatures glide gracefully between the towering concrete structures, their wide, membranous wings casting eerie shadows on the walls below. Their movement is smooth and languid, almost ethereal, as if they are part of the city's surreal atmosphere..."
wikitext
text/x-wiki
{{Needs location}}
'''Manta Rays''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|Immense flying manta rays drift silently through the shadowed expanse, their presence both mesmerizing and unsettling. These creatures glide gracefully between the towering concrete structures, their wide, membranous wings casting eerie shadows on the walls below. Their movement is smooth and languid, almost ethereal, as if they are part of the city's surreal atmosphere rather than intrusions into it.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
ad2110737544d96d1aa04ddb0ada3606e90c3a3b
Template:Navbox/Data logs
10
290
1555
1538
2025-09-12T22:45:45Z
Sharparam
284703
Fix link to manta rays data log
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard (data log)|Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[A Broken Reality]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays (data log)|Manta Rays]]
* [[Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[Understanding]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
dc4e37240549a2d6c18c620e9cdacd8fa4312551
1556
1555
2025-09-12T22:46:17Z
Sharparam
284703
Fix link to anomaly data log
wikitext
text/x-wiki
<!-- The data logs should be listed in the order they appear in-game, not alphabetical -->
{{Navbox
| {{{1|}}}
| template = Navbox/Data logs
| title = [[Data logs]]
| list1 =
* [[Monastery Impression]]
* [[Monastery Observation]]
* [[Psychosis]]
* [[Heartbeat]]
* [[Dreadguard (data log)|Dreadguard]]
* [[Inquisitors]]
* [[Shadows in the Courtyard]]
* [[Eternal Rain]]
* [[Habitation]]
* [[Industrial Silence]]
* [[Encrypted Radiation]]
* [[Dust Sea]]
* [[The Deep Monastery]]
* [[Monolith]]
* [[Desert Whispers]]
* [[Desert Dream]]
* [[Shifting Sands]]
* [[Vermillion]]
* [[A Broken Reality]]
* [[Asylum (data log)|Asylum]]
* [[Terror]]
* [[Night Horror]]
* [[The Banshee]]
* [[Umbral City]]
* [[Call of the Void]]
* [[Serpentine Visions]]
* [[The Deep]]
* [[A Vision]]
* [[The Drone]]
* [[Inhabitants]]
* [[Silent Streets]]
* [[Calcified Lives]]
* [[Statues]]
* [[Manta Rays (data log)|Manta Rays]]
* [[Anomaly (data log)|Anomaly]]
* [[Unknown Limits]]
* [[Kaleidoscope of Dreams]]
* [[The Structure]]
* [[Understanding]]
* [[The Grave Predicament]]
* [[Intercepted Transmission]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
2dc573d37563e98478c01e48e8dea6f348c2bfc6
Anomaly (data log)
0
941
1557
2025-09-12T22:50:53Z
Sharparam
284703
Created page with "{{About|the [[Data logs|data log]]||Anomaly (disambiguation)}} {{Needs location}} '''Anomaly''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |[[Anomaly|The anomaly]] manifests as a colossal armillary sphere, an incomprehensible construct of metal rings and shifting geometries that perpetually expands and devours everything in its path. This sphere, a swirling vortex of distorted space-time, continuously grows outward, assimilating buildings, ideas, an..."
wikitext
text/x-wiki
{{About|the [[Data logs|data log]]||Anomaly (disambiguation)}}
{{Needs location}}
'''Anomaly''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|[[Anomaly|The anomaly]] manifests as a colossal armillary sphere, an incomprehensible construct of metal rings and shifting geometries that perpetually expands and devours everything in its path. This sphere, a swirling vortex of distorted space-time, continuously grows outward, assimilating buildings, ideas, and entire segments of [[the Omnistructure]] into its ever-changing structure. Its rings twist and rotate with a relentless, almost sentient motion, consuming and reshaping reality around them.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
a1e0814fac5a4d47fc64d57a2e893e485cddf724
Anomaly (disambiguation)
0
942
1558
2025-09-12T22:53:28Z
Sharparam
284703
Redirected page to [[Anomaly]]
wikitext
text/x-wiki
#REDIRECT [[Anomaly]]
c369f0f98957b3c2574876f7e5df8d9cd36ba461
Anomaly (location)
0
363
1559
1519
2025-09-12T22:53:54Z
Sharparam
284703
Sharparam renamed page [[Anomaly]] to [[Anomaly (location)]] without leaving a redirect: Disambiguate
wikitext
text/x-wiki
[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]]
The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]]
== Gallery ==
<gallery>
File:Labyrinth_solution.jpg|Solution for the labyrinth.|alt=Screenshot showing a part of the labyrinth in the Anomaly area. The entrance is on the left, with a path to the center on the right drawn with a white line.
</gallery>
{{Navbox/Locations}}
[[Category:Locations]]
3d87ec3fa38d389e039733d0f695e0ee5f9b9be2
1560
1559
2025-09-12T22:54:47Z
Sharparam
284703
Add about template
wikitext
text/x-wiki
{{About|the [[Locations|location]]||Anomaly (disambiguation)}}
[[File:Anomaly.png|thumb|The anomaly as depicted in the game's relocation menu.|alt=Artwork showing the anomaly in the middle of a circular labyrinth.]]
The '''{{PAGENAME}}''' is a [[Locations|location]] in {{BFF}}.
{{Quote
| Reality melts into a surreal dreamscape. A sinister pressure emanates from the center. Time is still.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
=== Bosses ===
* [[Archinquisitor Belisarius (boss)|Archinquisitor Belisarius]]
== Gallery ==
<gallery>
File:Labyrinth_solution.jpg|Solution for the labyrinth.|alt=Screenshot showing a part of the labyrinth in the Anomaly area. The entrance is on the left, with a path to the center on the right drawn with a white line.
</gallery>
{{Navbox/Locations}}
[[Category:Locations]]
8d6ea6a0bd2f7e7855c41e8e88705aa6ee9a0d2d
Template:Navbox/Locations
10
293
1561
1289
2025-09-12T22:55:13Z
Sharparam
284703
Fix link to anomaly location
wikitext
text/x-wiki
<!-- The locations are ordered in the way they are listed in-game in the relocation menu -->
{{Navbox
| template = Navbox/Locations
| title = [[Locations]]
| list1 =
* [[Monastery]]
** [[Monastery#Lower|Lower]]
** [[Monastery#Upper|Upper]]
* [[Blok 6147]]
* [[Rain District]]
** [[Rain District#Sewers|Sewers]]
** [[Rain District#Center|Center]]
* [[Deluge]]
* [[Asylum]]
* [[Upper Blocks]]
* [[Uranopolis]]
** [[Uranopolis#Tower Complex|Tower Complex]]
** [[Uranopolis#Lone Tower|Lone Tower]]
* [[Ghost Town]]
** [[Ghost Town#Floor 13|Floor 13]]
** [[Ghost Town#Floor 1|Floor 1]]
* [[Machinarium]]
* [[Desert]]
* [[Desert Mirage]]
* [[Anomaly (location)|Anomaly]]
* [[Unknown (location)|Unknown]]
* [[Vermillion Fields]]
** [[Vermillion Fields#Plaza|Plaza]]
** [[Vermillion Fields#Temple|Temple]]
}}<noinclude>
{{Documentation}}
[[Category:Navigation templates]]
</noinclude>
abc8e58e564632cf59e52482d1c53f18578b1e8d
Anomaly
0
943
1562
2025-09-12T22:55:55Z
Sharparam
284703
Created page with "__DISAMBIG__ == Common meanings == * [[Anomaly (location)]] * [[Anomaly (data log)]] {{Disambiguation}}"
wikitext
text/x-wiki
__DISAMBIG__
== Common meanings ==
* [[Anomaly (location)]]
* [[Anomaly (data log)]]
{{Disambiguation}}
896baede274df850033dd62591f21daa44b7d273
1563
1562
2025-09-12T22:56:19Z
Sharparam
284703
Add introduction
wikitext
text/x-wiki
__DISAMBIG__
'''Anomaly''' may refer to:
== Common meanings ==
* [[Anomaly (location)]]
* [[Anomaly (data log)]]
{{Disambiguation}}
56c479cbbdc3615fd59f08079dce10eabfd05c9e
The Structure
0
944
1564
2025-09-12T23:00:34Z
Sharparam
284703
Created page with "{{About|the [[Data logs|data log]]|the environment in which a majority of the game takes place|The Omnistructure}} {{Needs location}} '''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}. == Overview == {{Quote |The true nature of [[the Omnistructure]] is a tightly guarded secret, known to only a few and barely understood even by those who claim to grasp it. Attempting to comprehend its vast and enigmatic complexity is so daunting that it often drives those who tr..."
wikitext
text/x-wiki
{{About|the [[Data logs|data log]]|the environment in which a majority of the game takes place|The Omnistructure}}
{{Needs location}}
'''{{PAGENAME}}''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|The true nature of [[the Omnistructure]] is a tightly guarded secret, known to only a few and barely understood even by those who claim to grasp it. Attempting to comprehend its vast and enigmatic complexity is so daunting that it often drives those who try to the brink of madness. Consequently, much of the research into the Omnistructure's nature is veiled in obscurity, with findings and progress shrouded in layers of secrecy and uncertainty.
}}
{{Navbox/Data logs}}
[[Category:Data logs]]
6260d2366eed67e54533371044fe5c076852b818
Dreadguard
0
945
1565
2025-09-12T23:10:22Z
Sharparam
284703
Created page with "__DISAMBIG__ '''Dreadguard''' may refer to: == Common meanings == * [[Dreadguard (NPC)]] * [[Dreadguard (enemy)]] * [[Dreadguarad (data log)]] {{Disambiguation}}"
wikitext
text/x-wiki
__DISAMBIG__
'''Dreadguard''' may refer to:
== Common meanings ==
* [[Dreadguard (NPC)]]
* [[Dreadguard (enemy)]]
* [[Dreadguarad (data log)]]
{{Disambiguation}}
802c97aef7c757ded9eb1cfd6bbd938f465df0b9
1566
1565
2025-09-12T23:10:35Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
__DISAMBIG__
'''Dreadguard''' may refer to:
== Common meanings ==
* [[Dreadguard (NPC)]]
* [[Dreadguard (enemy)]]
* [[Dreadguard (data log)]]
{{Disambiguation}}
daff31396c0e7cdc8a5575bbe11ff385e1dc3dec
Dreadguard (data log)
0
925
1567
1537
2025-09-12T23:11:18Z
Sharparam
284703
Add about template for disambiguation
wikitext
text/x-wiki
{{About|the [[Data logs|data log]]||Dreadguard (disambiguation)}}
{{Needs location}}
'''Dreadguard''' is a [[Data logs|data log]] in {{BFF}}.
== Overview ==
{{Quote
|What are these [[Dreadguard (NPC)|Dreadguard]] made of… not a flinch, not a single discernable sign of discomfort. I know their training is gruelling, but this level of fortitude goes beyond anything I've seen.
}}
== See also ==
* [[Dreadguard (NPC)]]
* [[Dreadguard (enemy)]]
{{Navbox/Data logs}}
[[Category:Data logs]]
70221f0a6c2be5edc5d65c4757e26b160ac00013
Dreadguard (disambiguation)
0
946
1568
2025-09-12T23:11:28Z
Sharparam
284703
Redirected page to [[Dreadguard]]
wikitext
text/x-wiki
#REDIRECT [[Dreadguard]]
8d7bcb54f0389c347d5b4e3f0f6fc39038ec6dc3
Bleak Faith: Forsaken Wiki/pages
0
5
1569
1355
2025-09-12T23:12:44Z
Sharparam
284703
Add link to lore page
wikitext
text/x-wiki
{{Main page box/start
| title = Useful wiki pages
| class = centered-content
}}
<div class="mp-links columns-2">
* {{MP link|Items|link=Items}}
* {{MP link|Enemies|link=Enemies}}
* {{MP link|NPCs|link=NPCs}}
* {{MP link|Locations|link=Locations}}
* {{MP link|Lore|link=Lore}}
</div>
{{Main page box/end}}<noinclude>[[Category:Main page boxes]]</noinclude><!-- don't edit this line -->
4410f18a121907d0872f3b4304e09239739595b2
Marrow
0
947
1570
2025-09-12T23:21:38Z
Sharparam
284703
Created page with "{{About|the weapon|the ability|Marrow (ability)}} {{Needs location}} {{Infobox/Weapon | image = Marrow (weapon).png | Type = Twinblade | Speed = Swift | Damage type = Sharp | Abilities = Marrow (ability),Bone Barrier | Mk_min = 3 | Mk3_Damage_min = 137 | Mk3_Damage_max = 141 }} '''{{PAGENAME}}''' is a [[Twinblades|twinblade weapon]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{About|the weapon|the ability|Marrow (ability)}}
{{Needs location}}
{{Infobox/Weapon
| image = Marrow (weapon).png
| Type = Twinblade
| Speed = Swift
| Damage type = Sharp
| Abilities = Marrow (ability),Bone Barrier
| Mk_min = 3
| Mk3_Damage_min = 137
| Mk3_Damage_max = 141
}}
'''{{PAGENAME}}''' is a [[Twinblades|twinblade weapon]] in {{BFF}}.
{{Navbox/Weapons}}
e2c903f6ce3a13c32a4eec7c2e147e3853ce4699
1575
1570
2025-09-12T23:44:34Z
Sharparam
284703
Update ability name
wikitext
text/x-wiki
{{About|the weapon|the ability|Marrow (ability)}}
{{Needs location}}
{{Infobox/Weapon
| image = Marrow (weapon).png
| Type = Twinblade
| Speed = Swift
| Damage type = Sharp
| Abilities = Marrow,Bone Barrier
| Mk_min = 3
| Mk3_Damage_min = 137
| Mk3_Damage_max = 141
}}
'''{{PAGENAME}}''' is a [[Twinblades|twinblade weapon]] in {{BFF}}.
{{Navbox/Weapons}}
e8ded381a75a0ed52bc39cfe57ca3870c374a33e
Template:Infobox/Weapon
10
451
1571
891
2025-09-12T23:22:11Z
Sharparam
284703
Improve passive and ability links
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@|@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@|@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
4445c1e03d8cded9694037701c935e0004037608
1574
1571
2025-09-12T23:43:38Z
Sharparam
284703
Use a template for ability link
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| pattern = * {{Ability link|@@@@}}
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
d5d23eaefabad807d97d7e6b0a478b1a64d94518
1576
1574
2025-09-12T23:47:36Z
Sharparam
284703
Use template parameter for ability list
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| template = Ability link
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
a7cec6f126ae4b4f1c22b8e47720e6fab2a190ea
1578
1576
2025-09-12T23:49:17Z
Sharparam
284703
Use better template for ability links
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| template = Ability link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
709ab3ef8fda5051b8aba6f4fa17630f591a8773
Template:Ability link
10
948
1572
2025-09-12T23:38:35Z
Sharparam
284703
Created page with "{{#switch:{{{1}}} | Marrow = [[Marrow (ability)|Marrow]] | #default = [[{{{1}}}]] }}<!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#switch:{{{1}}}
| Marrow = [[Marrow (ability)|Marrow]]
| #default = [[{{{1}}}]]
}}<!--
--><noinclude>{{Documentation}}</noinclude>
c39cdb6ae0c8a5d81c0d85b2e6b4bae2bfb7c744
Template:Ability link/doc
10
949
1573
2025-09-12T23:42:48Z
Sharparam
284703
Created page with "Used to produce a link to an [[Abilities|ability]]. This is primarily useful to automatically handle cases where an ability shares a name with some other page, in which case the article for the ability is usually named with a " (ability)" suffix. == TemplateData == <templatedata> { "params": { "1": { "label": "Ability", "description": "The ability to link to", "example": "Marrow", "type": "line", "required": true } }, "description": "Generate a li..."
wikitext
text/x-wiki
Used to produce a link to an [[Abilities|ability]].
This is primarily useful to automatically handle cases where an ability shares a name with some other page, in which case the article for the ability is usually named with a " (ability)" suffix.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Ability",
"description": "The ability to link to",
"example": "Marrow",
"type": "line",
"required": true
}
},
"description": "Generate a link to an ability.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Ability link|Blade Dash}}</syntaxhighlight> → {{Ability link|Blade dash}}
* <syntaxhighlight lang="wikitext" inline>{{Ability link|Marrow}}</syntaxhighlight> → {{Ability link|Marrow}}
Note how in the "Marrow" example, the link goes to "Marrow (ability)" without having to specify it manually.
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
b7cc18628d99f464440f1358cdb8ff29759c790a
1587
1573
2025-09-13T00:03:29Z
Sharparam
284703
/* Examples */ Fix blade dash example
wikitext
text/x-wiki
Used to produce a link to an [[Abilities|ability]].
This is primarily useful to automatically handle cases where an ability shares a name with some other page, in which case the article for the ability is usually named with a " (ability)" suffix.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Ability",
"description": "The ability to link to",
"example": "Marrow",
"type": "line",
"required": true
}
},
"description": "Generate a link to an ability.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Ability link|Blade Dash}}</syntaxhighlight> → {{Ability link|Blade Dash}}
* <syntaxhighlight lang="wikitext" inline>{{Ability link|Marrow}}</syntaxhighlight> → {{Ability link|Marrow}}
Note how in the "Marrow" example, the link goes to "Marrow (ability)" without having to specify it manually.
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
c8f5da080e8ebe27d1e317cfee2963c1752dd571
Template:Ability link item
10
950
1577
2025-09-12T23:48:42Z
Sharparam
284703
Created page with "* {{Ability link|{{{1}}}}}<!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
* {{Ability link|{{{1}}}}}<!--
--><noinclude>{{Documentation}}</noinclude>
d357d99a640c1b615d8baad3b65ebbe2def15486
Template:Ability link item/doc
10
951
1579
2025-09-12T23:50:44Z
Sharparam
284703
Created page with "Used in [[:Category:Infobox templates|infobox templates]] for ability link lists. Not intended for usage elsewhere. <includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
Used in [[:Category:Infobox templates|infobox templates]] for ability link lists. Not intended for usage elsewhere.
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
cd60abe8a158af756ecbe36cd2983bdecff37715
File:Marrow (weapon).png
6
952
1580
2025-09-12T23:51:56Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Marrow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Marrow
}}
== Licensing ==
{{License|game}}
ba777602a1ac564d62d83c7006fd995bade00fce
Marrow (ability)
0
953
1581
2025-09-12T23:54:56Z
Sharparam
284703
Created page with "{{About|the ability|the weapon|Marrow}} {{Infobox/Ability | title = Marrow | image = Marrow (ability).png | Description = Send forward a marrow snake which damages and ruptures all enemies that come in contact with it. 206 damage and additional 154 from [[Agility]] attribute per instance of damage for a total of 360 [[Sharp]] damage. | Cooldown = 25 | Cost = 60 }} '''Marrow''' is an [[Abilities|ability]] in {{BFF}} that can be found on the [[Marrow]] weapon. {{Navbox/A..."
wikitext
text/x-wiki
{{About|the ability|the weapon|Marrow}}
{{Infobox/Ability
| title = Marrow
| image = Marrow (ability).png
| Description = Send forward a marrow snake which damages and ruptures all enemies that come in contact with it.
206 damage and additional 154 from [[Agility]] attribute per instance of damage for a total of 360 [[Sharp]] damage.
| Cooldown = 25
| Cost = 60
}}
'''Marrow''' is an [[Abilities|ability]] in {{BFF}} that can be found on the [[Marrow]] weapon.
{{Navbox/Abilities}}
f6051ca012e67d0625759cf5a17a22736c920d1c
Template:Navbox/Abilities
10
578
1582
920
2025-09-12T23:55:14Z
Sharparam
284703
Add marrow ability
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = [[Abilities]]
| list1 =
* [[Blade Dash]]
* [[Divine Blessing]]
* [[Marrow (ability)|Marrow]]
* [[Whirlwind Strike]]
}}<noinclude>{{Documentation}}</noinclude>
a7532ede7ee4e5698b18ab647a57ed0d9c8b3a6f
1585
1582
2025-09-12T23:58:31Z
Sharparam
284703
Add bone barrier ability
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = [[Abilities]]
| list1 =
* [[Blade Dash]]
* [[Bone Barrier]]
* [[Divine Blessing]]
* [[Marrow (ability)|Marrow]]
* [[Whirlwind Strike]]
}}<noinclude>{{Documentation}}</noinclude>
1999c737dfabe0b3296b8ef5ab83fdcba1f3beec
File:Marrow (ability).png
6
954
1583
2025-09-12T23:56:19Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Marrow1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Marrow1
}}
== Licensing ==
{{License|game}}
d12a981eec5ed7d9a1d28e96b83da4d179754574
Bone Barrier
0
955
1584
2025-09-12T23:58:10Z
Sharparam
284703
Created page with "{{Infobox/Ability | title = Bone Barrier | image = Bone Barrier (ability).png | Description = Creates a bone barrier around you, which damages and ruptures all enemies that come in contact with it. 131 damage and additional 98 from [[Agility]] attribute per instance of damage for a total of 229 [[Sharp]] damage. | Cooldown = 60 | Cost = 60 }} '''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}. {{Navbox/Abilities}}"
wikitext
text/x-wiki
{{Infobox/Ability
| title = Bone Barrier
| image = Bone Barrier (ability).png
| Description = Creates a bone barrier around you, which damages and ruptures all enemies that come in contact with it.
131 damage and additional 98 from [[Agility]] attribute per instance of damage for a total of 229 [[Sharp]] damage.
| Cooldown = 60
| Cost = 60
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
54551d5092bd238ae37f87fb6108a654f6a7c33f
File:Bone Barrier (ability).png
6
956
1586
2025-09-12T23:59:09Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Marrow2
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_Marrow2
}}
== Licensing ==
{{License|game}}
feede77956a2fd35389f1e5b1fce8db8866fc1eb
Template:Infobox/Armor set
10
455
1588
675
2025-09-13T00:29:01Z
Sharparam
284703
Add support for Mk 0 and setting minimum Mk
wikitext
text/x-wiki
<includeonly><!--
-->{{#invoke:Infobox|main
|kind=armor-set
|sep=,
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Pieces, Stats
|Basic Info=Weight
|Pieces=Helmet,Pauldrons,Chestguard,Legguard,Gauntlets
|Helmet={{#if:{{{Helmet|}}}|[[{{{Helmet}}}]]}}
|Pauldrons={{#if:{{{Pauldrons|}}}|[[{{{Pauldrons}}}]]}}
|Chestguard={{#if:{{{Chestguard|}}}|[[{{{Chestguard}}}]]}}
|Legguard={{#if:{{{Legguard|}}}|[[{{{Legguard}}}]]}}
|Gauntlets={{#if:{{{Gauntlets|}}}|[[{{{Gauntlets}}}]]}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Sharp,Blunt,Technomancy
|Sharp_label=[[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
|Blunt_label=[[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
|Technomancy_label=[[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
|Mk0_Sharp={{{Mk0_Sharp|???}}}
|Mk0_Blunt={{{Mk0_Blunt|???}}}
|Mk0_Technomancy={{{Mk0_Technomancy|???}}}
|Mk1_Sharp={{{Mk1_Sharp|???}}}
|Mk1_Blunt={{{Mk1_Blunt|???}}}
|Mk1_Technomancy={{{Mk1_Technomancy|???}}}
|Mk2_Sharp={{{Mk2_Sharp|???}}}
|Mk2_Blunt={{{Mk2_Blunt|???}}}
|Mk2_Technomancy={{{Mk2_Technomancy|???}}}
|Mk3_Sharp={{{Mk3_Sharp|???}}}
|Mk3_Blunt={{{Mk3_Blunt|???}}}
|Mk3_Technomancy={{{Mk3_Technomancy|???}}}
|Mk4_Sharp={{{Mk4_Sharp|???}}}
|Mk4_Blunt={{{Mk4_Blunt|???}}}
|Mk4_Technomancy={{{Mk4_Technomancy|???}}}
|Mk5_Sharp={{{Mk5_Sharp|???}}}
|Mk5_Blunt={{{Mk5_Blunt|???}}}
|Mk5_Technomancy={{{Mk5_Technomancy|???}}}
}}{{#if:{{NAMESPACE}}||[[Category:Armor sets]]}}</includeonly><noinclude>
{{Documentation}}[[Category:Infobox templates]]</noinclude>
7c1ef287755c498a7d24574f795db74af44164d2
Template:Infobox/Armor set/doc
10
456
1589
677
2025-09-13T00:31:26Z
Sharparam
284703
Add missing params in docs
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for an armor set",
"params": {
"image": {
"label": "Armor set image",
"description": "Name of the file used as the image for the armor set, should be at least 300 pixels wide.",
"required": true,
"example": "Cool armor set.png",
"type": "wiki-file-name"
},
"Weight": {
"label": "Armor set weight",
"description": "The weight class of the armor set.",
"required": true,
"example": "Light",
"type": "string"
},
"Helmet": {
"label": "Helmet piece",
"description": "The armor used for the helmet slot.",
"required": true,
"example": "Cool Helmet",
"type": "wiki-page-name"
},
"Pauldrons": {
"label": "Pauldrons piece",
"description": "The armor used for the pauldrons slot.",
"required": true,
"example": "Cool Pauldrons",
"type": "wiki-page-name"
},
"Chestguard": {
"label": "Chestguard piece",
"description": "The armor used for the chestguard slot.",
"required": true,
"example": "Cool Chestguard",
"type": "wiki-page-name"
},
"Legguard": {
"label": "Legguard piece",
"description": "The armor used for the legguard slot.",
"required": true,
"example": "Cool Legguard",
"type": "wiki-page-name"
},
"Gauntlets": {
"label": "Gauntlets piece",
"description": "The armor used for the gauntlets slot.",
"required": true,
"example": "Cool Gauntlets",
"type": "wiki-page-name"
},
"Mk_min": {
"label": "Minimum Mk",
"description": "Minimum Mk level the armor set can be found at",
"required": false,
"suggested": true,
"example": "3",
"default": "0",
"type": "number"
},
"Mk0_Sharp": {
"label": "Mk 0 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 0",
"required": true,
"example": "1",
"type": "number"
},
"Mk0_Blunt": {
"label": "Mk 0 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 0",
"required": true,
"example": "1",
"type": "number"
},
"Mk0_Technomancy": {
"label": "Mk 0 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 0",
"required": true,
"example": "1",
"type": "number"
},
"Mk1_Sharp": {
"label": "Mk 1 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Blunt": {
"label": "Mk 1 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Technomancy": {
"label": "Mk 1 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Sharp": {
"label": "Mk 2 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Blunt": {
"label": "Mk 2 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk2_Technomancy": {
"label": "Mk 2 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 2",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Sharp": {
"label": "Mk 3 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Blunt": {
"label": "Mk 3 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk3_Technomancy": {
"label": "Mk 3 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 3",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Sharp": {
"label": "Mk 4 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Blunt": {
"label": "Mk 4 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk4_Technomancy": {
"label": "Mk 4 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 4",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Sharp": {
"label": "Mk 5 sharp rating",
"description": "Total sharp defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Blunt": {
"label": "Mk 5 blunt rating",
"description": "Total blunt defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
},
"Mk5_Technomancy": {
"label": "Mk 5 technomancy rating",
"description": "Total technomancy defense rating for the full set at Mk 5",
"required": true,
"example": "5",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Armor set
| image = Awesome set.png
| title = Awesome set
| Weight = Heavy
| Helmet = Awesome Helmet
| Pauldrons = Awesome Pauldrons
| Chestguard = Awesome Chestguard
| Legguard = Awesome Legguard
| Gauntlets = Awesome Gauntlets
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Armor set
| image = Awesome set.png
| title = Awesome set
| Weight = Heavy
| Helmet = Awesome Helmet
| Pauldrons = Awesome Pauldrons
| Chestguard = Awesome Chestguard
| Legguard = Awesome Legguard
| Gauntlets = Awesome Gauntlets
| Mk1_Sharp = 1
| Mk1_Blunt = 2
| Mk1_Technomancy = 4
| Mk2_Sharp = 2
| Mk2_Blunt = 4
| Mk2_Technomancy = 8
| Mk3_Sharp = 4
| Mk3_Blunt = 8
| Mk3_Technomancy = 16
| Mk4_Sharp = 8
| Mk4_Blunt = 16
| Mk4_Technomancy = 32
| Mk5_Sharp = 16
| Mk5_Blunt = 32
| Mk5_Technomancy = 64
}}
</syntaxhighlight>
63b0ca611a0361adfe0782cc13f2a80410b5c5b2
Stalker
0
957
1590
2025-09-13T00:31:50Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Armor set | title = {{PAGENAME}} | image = Stalker (armor set).png | Helmet = Stalker's Hood | Chestguard = Stalker's Cuirass | Legguard = Stalker's Pants | Gauntlets = Stalker's Gloves }} '''Stalker''' is an [[Armor sets|armor set]] in {{BFF}}. {{Navbox/Armor}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Armor set
| title = {{PAGENAME}}
| image = Stalker (armor set).png
| Helmet = Stalker's Hood
| Chestguard = Stalker's Cuirass
| Legguard = Stalker's Pants
| Gauntlets = Stalker's Gloves
}}
'''Stalker''' is an [[Armor sets|armor set]] in {{BFF}}.
{{Navbox/Armor}}
9557181feaf758a44fdde490492d76e9b5e6886b
1593
1590
2025-09-13T00:37:23Z
Sharparam
284703
Add Mk 1 stats
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Armor set
| title = {{PAGENAME}}
| image = Stalker (armor set).png
| Helmet = Stalker's Hood
| Chestguard = Stalker's Cuirass
| Legguard = Stalker's Pants
| Gauntlets = Stalker's Gloves
| Mk_min = 1
| Mk1_Sharp = 1740
| Mk1_Blunt = 1894
| Mk1_Technomancy = 2428
}}
'''Stalker''' is an [[Armor sets|armor set]] in {{BFF}}.
{{Navbox/Armor}}
2f2d7ce5ce0f99cae1ec2aac2a6417188ff049b2
File:Stalker (armor set).png
6
958
1591
2025-09-13T00:33:19Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
1592
1591
2025-09-13T00:35:08Z
Sharparam
284703
Sharparam uploaded a new version of [[File:Stalker (armor set).png]]
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Mutated Ghoul
0
552
1594
865
2025-09-13T00:43:41Z
Sharparam
284703
Update image link
wikitext
text/x-wiki
{{Infobox/Boss
| image = Mutated Ghoul (boss).png
}}
'''{{PAGENAME}}''' is an optional [[Bosses|boss]] in {{BFF}}.
== Location ==
{{coords|6937.36|-64861.39|-17736.47}} (approximate)
Located in a big grass field at the bottom of the [[Monastery]].
== Drops ==
* [[Anomalous Fragment]] (only in [[NG+]])
{{Navbox/Bosses}}
2fec400e2da1a3a299f24e03158d8f5786e5cf02
File:Mutated Ghoul (boss).png
6
959
1595
2025-09-13T00:43:57Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
MediaWiki:Sidebar
8
324
1596
958
2025-09-13T00:45:22Z
Sharparam
284703
Add link to lore
wikitext
text/x-wiki
* navigation
** mainpage|mainpage-description
** recentchanges-url|recentchanges
** Special:NewFiles|New files
** randompage-url|randompage
* Bleak Faith
** Items
** Locations
** NPCs
** Enemies
** Bosses
** Lore
* sidebar-customizing-wiki
** MediaWiki:Sidebar|sidebar-edit-sidebar
** MediaWiki:Common.css|sidebar-edit-common-css
** MediaWiki:Vector.css|sidebar-edit-vector-css
** MediaWiki:Common.js|sidebar-edit-common-js
** Special:Gadgets|sidebar-gadgets
** Special:Import|sidebar-special-import
** Special:Export|sidebar-special-export
** Special:AllPages|sidebar-all-pages
** Special:SpecialPages|sidebar-special-pages
* wiki.gg
** support:|sidebar-support-wiki
** Wikigg-ticket-link|sidebar-submit-ticket
** wikigg-socialmedia-joinlink|wikigg-socialmedia-jointext-sidebar
6b7ee923f37b111533d902d0ae28c62b872ffc9e
Template:Infobox/Boss/doc
10
861
1597
1363
2025-09-13T00:46:57Z
Sharparam
284703
Use Konrad for example
wikitext
text/x-wiki
== Examples ==
{{Infobox/Boss
| title = Konrad the Traitor
| image = Konrad the Traitor.png
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Boss
| title = Konrad the Traitor
| image = Konrad the Traitor.png
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
8120c02bb422349ab95b63725c3fd58597dc2a51
Template:Infobox/Weapon/doc
10
452
1598
669
2025-09-13T00:47:40Z
Sharparam
284703
/* Example */ Use Katanas for example
wikitext
text/x-wiki
== Usage ==
<templatedata>
{
"description": "Infobox template for weapons",
"params": {
"title": {
"label": "Weapon name",
"description": "The name of the weapon",
"required": false,
"default": "{{PAGENAME}}",
"example": "Cool Sword",
"type": "string"
},
"image": {
"label": "Weapon image",
"description": "Name of the file used as the image for the weapon, should be at least 300 pixels wide.",
"required": true,
"example": "Cool weapon.png",
"type": "wiki-file-name"
},
"Type": {
"label": "Weapon type",
"description": "The type of the weapon.",
"required": true,
"example": "Dual Wields",
"type": "wiki-page-name"
},
"Speed": {
"label": "Weapon speed",
"description": "The speed category of the weapon.",
"required": true,
"example": "Fast",
"type": "string"
},
"Damage type": {
"label": "Weapon damage type",
"description": "The type of damage dealt by the weapon.",
"required": true,
"example": "Sharp",
"type": "wiki-page-name"
},
"Passives": {
"label": "Passive properties",
"description": "Any passive properties the weapon has, comma separated",
"required": false,
"example": "Health Regen, Flux Regen",
"type": "string"
},
"Abilities": {
"label": "Active abilities",
"description": "Active abilities that can be used when the weapon is equipped, comma separated",
"required": false,
"example": "Blade Dance",
"type": "string"
},
"Mk_min": {
"label": "Minimum mark level",
"description": "The initial mark level of the weapon",
"required": false,
"default": "0",
"example": "3",
"type": "number"
},
"Mk0_Damage_min": {
"label": "Min. damage at Mk. 0",
"description": "Minimum damage the weapon deals at Mk. 0",
"required": true,
"example": "5",
"type": "number"
},
"Mk0_Damage_max": {
"label": "Max. damage at Mk. 0",
"description": "Maximum damage the weapon deals at Mk. 0",
"required": true,
"example": "8",
"type": "number"
},
"Mk1_Damage_min": {
"label": "Min. damage at Mk. 1",
"description": "Minimum damage the weapon deals at Mk. 1",
"required": true,
"example": "5",
"type": "number"
},
"Mk1_Damage_max": {
"label": "Max. damage at Mk. 1",
"description": "Maximum damage the weapon deals at Mk. 1",
"required": true,
"example": "8",
"type": "number"
},
"Mk2_Damage_min": {
"label": "Min. damage at Mk. 2",
"description": "Minimum damage the weapon deals at Mk. 2",
"required": true,
"example": "10",
"type": "number"
},
"Mk2_Damage_max": {
"label": "Max. damage at Mk. 2",
"description": "Maximum damage the weapon deals at Mk. 2",
"required": true,
"example": "15",
"type": "number"
},
"Mk3_Damage_min": {
"label": "Min. damage at Mk. 3",
"description": "Minimum damage the weapon deals at Mk. 3",
"required": true,
"example": "20",
"type": "number"
},
"Mk3_Damage_max": {
"label": "Max. damage at Mk. 3",
"description": "Maximum damage the weapon deals at Mk. 3",
"required": true,
"example": "25",
"type": "number"
},
"Mk4_Damage_min": {
"label": "Min. damage at Mk. 4",
"description": "Minimum damage the weapon deals at Mk. 4",
"required": true,
"example": "30",
"type": "number"
},
"Mk4_Damage_max": {
"label": "Max. damage at Mk. 4",
"description": "Maximum damage the weapon deals at Mk. 4",
"required": true,
"example": "40",
"type": "number"
},
"Mk5_Damage_min": {
"label": "Min. damage at Mk. 5",
"description": "Minimum damage the weapon deals at Mk. 5",
"required": true,
"example": "50",
"type": "number"
},
"Mk5_Damage_max": {
"label": "Max. damage at Mk. 5",
"description": "Maximum damage the weapon deals at Mk. 5",
"required": true,
"example": "60",
"type": "number"
}
},
"format": "block"
}
</templatedata>
== Example ==
{{Infobox/Weapon
| title = Katanas
| image = Katanas.png
| Type = Dual Wields
| Speed = Fast
| Damage type = Sharp
| Passives = Infinite regen,Stuff,Cool
| Abilities = Blade Dance
| Mk_min = 1
| Mk1_Damage_min = 1
| Mk1_Damage_max = 2
| Mk2_Damage_min = 4
| Mk2_Damage_max = 6
| Mk3_Damage_min = 10
| Mk3_Damage_max = 12
| Mk4_Damage_min = 20
| Mk4_Damage_max = 25
| Mk5_Damage_min = 50
| Mk5_Damage_max = 60
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Weapon
| title = Katanas
| image = Katanas.png
| Type = Dual Wields
| Speed = Fast
| Damage type = Sharp
| Passives = Infinite regen
| Abilities = Blade Dance
| Mk_min = 1
| Mk1_Damage_min = 1
| Mk1_Damage_max = 2
| Mk2_Damage_min = 4
| Mk2_Damage_max = 6
| Mk3_Damage_min = 10
| Mk3_Damage_max = 12
| Mk4_Damage_min = 20
| Mk4_Damage_max = 25
| Mk5_Damage_min = 50
| Mk5_Damage_max = 60
}}
</syntaxhighlight>
bfcdbd7a6f344c47407707ca0509e20db4608c7b
Yaroslav
0
403
1599
568
2025-09-13T00:52:05Z
Sharparam
284703
/* Location */ Fix coordinates and location link
wikitext
text/x-wiki
{{Infobox/NPC
| image = Yaroslav.png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|37597.55|115053.53|-139783.83}}
Located in the [[Desert]]. Standing with his crew in front of the gate to the [[Anomaly (location)|Anomaly]].
== Quotes ==
=== First encounter ===
{{Quote
|Welcome to [[The Anomaly|the anomaly]]. The dream of uncertainty. Here, even reality amounts to nothing.
Time is not of the essence here… Only choice. Soon, you'll feel it yourself.
Sometimes, I hear it all again. The voice of a girl… The color of her eyes… Frightening yet beautiful… Like mornings at war. Hours before the storm… You breathe in deeply, for it may be your last. The vast sky… And between the cold air and the smoke, a ray of sunshine on your face…
Beyond those gates, you will have to carry the greatest burden of all – your own!
The crusade they've mustered is blind with power… my own kind, crippled by ignorance… we are lost… lost in the wilderness!
I have not seen her for so long, I wonder if she was even real… A daughter imagined in dreams perhaps… Winds be with her.
I too am tired, but I gaze into the fire as it burns slowly – my eyes wide open. Some moths gather around the flame and they fly straight into it. Others fly in too and even more follow… All night long, without as much as a rustle, they melt away… I did not fear death then… but I was beginning to fear for my life.
We enslaved what was left of the Forsaken… We crucified the Mechanomads for raiding time itself… We brought light to darkness and blinded all who refused to see… And even here, at the gates to the anomaly, we flay all who dare approach. You understand such methods… After all, your own path is a river of blood and deception…
When you return, Collector, things will not be as they were. You will not be as you were.
}}
=== After first encounter ===
{{Quote|When you return, Collector, things will not be as they were. You will not be as you were.}}
=== Cutscene when leaving the [[Desert]] to enter the [[Anomaly]] ===
{{Quote
|Things have been set in motion that can never be explained.
An eternal rain is coming our way – remember to trust your blade. You will need it more than ever.
}}
{{Navbox/NPCs}}
5ffe13204acf7db33ee1129652016f3e984bc004
1600
1599
2025-09-13T00:52:27Z
Sharparam
284703
Update image link
wikitext
text/x-wiki
{{Infobox/NPC
| image = Yaroslav (NPC).png
}}
'''{{PAGENAME}}''' is an [[NPC]] in {{BFF}}.
== Location ==
{{coords|37597.55|115053.53|-139783.83}}
Located in the [[Desert]]. Standing with his crew in front of the gate to the [[Anomaly (location)|Anomaly]].
== Quotes ==
=== First encounter ===
{{Quote
|Welcome to [[The Anomaly|the anomaly]]. The dream of uncertainty. Here, even reality amounts to nothing.
Time is not of the essence here… Only choice. Soon, you'll feel it yourself.
Sometimes, I hear it all again. The voice of a girl… The color of her eyes… Frightening yet beautiful… Like mornings at war. Hours before the storm… You breathe in deeply, for it may be your last. The vast sky… And between the cold air and the smoke, a ray of sunshine on your face…
Beyond those gates, you will have to carry the greatest burden of all – your own!
The crusade they've mustered is blind with power… my own kind, crippled by ignorance… we are lost… lost in the wilderness!
I have not seen her for so long, I wonder if she was even real… A daughter imagined in dreams perhaps… Winds be with her.
I too am tired, but I gaze into the fire as it burns slowly – my eyes wide open. Some moths gather around the flame and they fly straight into it. Others fly in too and even more follow… All night long, without as much as a rustle, they melt away… I did not fear death then… but I was beginning to fear for my life.
We enslaved what was left of the Forsaken… We crucified the Mechanomads for raiding time itself… We brought light to darkness and blinded all who refused to see… And even here, at the gates to the anomaly, we flay all who dare approach. You understand such methods… After all, your own path is a river of blood and deception…
When you return, Collector, things will not be as they were. You will not be as you were.
}}
=== After first encounter ===
{{Quote|When you return, Collector, things will not be as they were. You will not be as you were.}}
=== Cutscene when leaving the [[Desert]] to enter the [[Anomaly]] ===
{{Quote
|Things have been set in motion that can never be explained.
An eternal rain is coming our way – remember to trust your blade. You will need it more than ever.
}}
{{Navbox/NPCs}}
bed8bdf7dfb54ff6627595b68af2e967f0ad7d77
File:Yaroslav (NPC).png
6
960
1601
2025-09-13T00:54:36Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Wormlord
0
547
1602
1493
2025-09-13T00:57:15Z
Sharparam
284703
/* Location */ Fix coordinates
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Wormlord.png
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Overview ==
Defeating Wormlord is required to be able to access [[Anomaly|the Anomaly]].
== Location ==
{{coords|262124.20|-51428.26|-120431.34}} (approximate, as the boss constantly moves around)
Found in [[Desert Mirage]]. The entire area is dedicated as its boss arena.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
66d200ece97308e9d63f6c38f248e0b26af266c6
1604
1602
2025-09-13T00:58:55Z
Sharparam
284703
Update image link
wikitext
text/x-wiki
{{Infobox/Boss
| title = {{PAGENAME}}
| image = Wormlord (boss).png
}}
'''{{PAGENAME}}''' is a mandatory [[Bosses|boss]] enemy in {{BFF}}.
== Overview ==
Defeating Wormlord is required to be able to access [[Anomaly|the Anomaly]].
== Location ==
{{coords|262124.20|-51428.26|-120431.34}} (approximate, as the boss constantly moves around)
Found in [[Desert Mirage]]. The entire area is dedicated as its boss arena.
== Drops ==
* [[Unstable Perk Essence]]
{{Navbox/Bosses}}
72448382acac08e4e72a6654ebd50a19585babaa
Module:Coordinates
828
296
1603
1465
2025-09-13T00:58:22Z
Sharparam
284703
Fix wrong variables used
Scribunto
text/plain
local FULL_SPECIFIED_PATTERN = "^%d+%.%d%d+$"
local NS_TO_CATEGORISE = {
[0] = true, -- main
[6] = true, -- file
[14] = true -- category
}
local CHECK_PATTERN = "^-?%d+%.%d%d$"
local args_util = require('Module:ArgsUtil')
local p = {}
---@param val number
---@param label string
local function coordNode(val, label)
return mw.html.create('span')
:addClass(label)
:wikitext(p.formatCoord(val))
end
---@param val number
---@return string
function p.formatCoord(val)
local sign = val < 0 and '-' or ''
val = math.abs(val)
val = math.floor(val * 100) / 100
local str = tostring(val)
local int = string.match(str, "^%d+")
local dec = string.match(str, "%.(%d-)0*$") or ''
local int_len = #int
local dec_len = #dec
if int_len >= 3 then
return sign .. string.sub(int, 1, 4)
end
if dec_len == 0 then return sign .. int end
return string.format("%s%s.%s", sign, int, string.sub(dec, 1, int_len == 2 and 1 or 2))
end
function p.main(frame)
local args = args_util.merge()
return p._main(args)
end
function p._main(args)
local x = args.x or args[1] or ""
local y = args.y or args[2] or ""
local z = args.z or args[3] or ""
local accurate_x = string.match(x, CHECK_PATTERN) ~= nil
local accurate_y = string.match(y, CHECK_PATTERN) ~= nil
local accurate_z = string.match(z, CHECK_PATTERN) ~= nil
local accurate = accurate_x or accurate_y or accurate_z
x = tonumber(x) or 0
y = tonumber(y) or 0
z = tonumber(z) or 0
local tooltip = string.format("X: %.2f, Y: %.2f, Z: %.2f", x, y, z)
local elem = mw.html.create('span')
:attr('data-x', x)
:attr('data-y', y)
:attr('data-z', z)
:attr('title', tooltip)
:addClass('coordinates')
:addClass('nowrap')
:node(coordNode(x, 'x'))
:wikitext('::')
:node(coordNode(y, 'y'))
:wikitext('::')
:node(coordNode(z, 'z'))
if not accurate then
elem = elem:addClass('inaccurate')
end
elem = tostring(elem)
local ns = mw.title.getCurrentTitle().namespace
if NS_TO_CATEGORISE[ns] then
if not accurate then
elem = elem .. '[[Category:Pages with inaccurate coordinates]]'
end
elem = elem .. '[[Category:Pages with coordinates]]'
end
local with_styles = mw.getCurrentFrame():extensionTag {
name = 'templatestyles',
args = { src = 'Module:Coordinates/styles.css' }
} .. elem
return with_styles
end
return p
2d305461aa30b6d7d764ddd922920b8d55c4af6a
File:Wormlord (boss).png
6
961
1605
2025-09-13T01:02:03Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Template:Coordinates/doc
10
298
1606
1466
2025-09-13T01:21:23Z
Sharparam
284703
Add category for template
wikitext
text/x-wiki
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.5",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.6",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12.42|y=50.00|z=-32.70}}</syntaxhighlight> → {{Coordinates|x=12.42|y=50.00|z=-32.70}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.51|42.55|-4.43}}</syntaxhighlight> → {{Coordinates|16.51|42.55|-4.43}}
* <syntaxhighlight lang="wikitext" inline>{{coords|1.23|4.56|7.89}}</syntaxhighlight> → {{coords|1.23|4.56|7.89}}
* <syntaxhighlight lang="wikitext" inline>{{pos|6.51|4.32|2.13}}</syntaxhighlight> → {{pos|6.51|4.32|2.13}}
Supplying inaccurate coordinates (not using two decimals) will produce an error underline to make them easy to spot:
<syntaxhighlight lang="wikitext" inline>{{coords|1|2|3}}</syntaxhighlight> → {{coords|1|2|3}}
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
34f70e284b9b28221942957e8fdd12ac44bb3b22
1607
1606
2025-09-13T01:25:08Z
Sharparam
284703
Add note on how to get accurate coordinates
wikitext
text/x-wiki
Template to specify a coordinate in the game.
'''Note:''' Due to a bug in the game, the in-game coordinate display {{strong|cannot}} be used to obtain accurate coordinates. Instead, you must use [https://framedsc.com/GeneralGuides/universal_ue4_consoleunlocker.htm the Unreal Engine 4 unlocker] software to enable the in-game console, and use the <code>showdebug</code> command to show a debug overlay that has accurate coordinates in it.
If you try to use the coordinates displayed in the UI in-game, it will be marked as an error on the wiki.
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.5",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.6",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12.42|y=50.00|z=-32.70}}</syntaxhighlight> → {{Coordinates|x=12.42|y=50.00|z=-32.70}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.51|42.55|-4.43}}</syntaxhighlight> → {{Coordinates|16.51|42.55|-4.43}}
* <syntaxhighlight lang="wikitext" inline>{{coords|1.23|4.56|7.89}}</syntaxhighlight> → {{coords|1.23|4.56|7.89}}
* <syntaxhighlight lang="wikitext" inline>{{pos|6.51|4.32|2.13}}</syntaxhighlight> → {{pos|6.51|4.32|2.13}}
Supplying inaccurate coordinates (not using two decimals) will produce an error underline to make them easy to spot:
<syntaxhighlight lang="wikitext" inline>{{coords|1|2|3}}</syntaxhighlight> → {{coords|1|2|3}}
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
b0fa377634ba6ba3b7b48458c0c4d35dfa342960
1609
1607
2025-09-13T01:37:29Z
Sharparam
284703
Improve documentation
wikitext
text/x-wiki
Template to specify a coordinate in the game.
'''Note:''' Due to a bug in the game, the in-game coordinate display {{strong|cannot}} be used to obtain accurate coordinates. Instead, [https://framedsc.com/GeneralGuides/universal_ue4_consoleunlocker.htm the Unreal Engine 4 unlocker] software must be used to enable the in-game console, after which the <code>showdebug</code> command can be used to show a debug overlay that has accurate coordinates in it.
[[File:Debug overlay.png|frame|left|The debug overlay as it appears in-game. The second "Location" line contains accurate coordinates (X, Y, and Z).|alt=Screenshot showing the debug overlay that can be enabled in the game if using certain third-party software.]]
{{clear}}
If you try to use the coordinates displayed in the UI in-game, it will be marked as an error on the wiki.
This template uses the {{ml|Coordinates}} Lua module.
== Usage ==
<templatedata>
{
"params": {
"x": {
"aliases": [
"1"
],
"label": "X",
"description": "X coordinate",
"example": "52.13",
"type": "number",
"required": true
},
"y": {
"aliases": [
"2"
],
"label": "Y",
"description": "Y coordinate",
"example": "12.59",
"type": "number",
"required": true
},
"z": {
"aliases": [
"3"
],
"label": "Z",
"description": "Z coordinate (vertical axis)",
"example": "-5.60",
"type": "number",
"required": true
}
},
"description": "Used to describe a location in the game.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|x=12.42|y=50.00|z=-32.70}}</syntaxhighlight> → {{Coordinates|x=12.42|y=50.00|z=-32.70}}
* <syntaxhighlight lang="wikitext" inline>{{Coordinates|16.51|42.55|-4.43}}</syntaxhighlight> → {{Coordinates|16.51|42.55|-4.43}}
* <syntaxhighlight lang="wikitext" inline>{{coords|1.23|4.56|7.89}}</syntaxhighlight> → {{coords|1.23|4.56|7.89}}
* <syntaxhighlight lang="wikitext" inline>{{pos|6.51|4.32|2.13}}</syntaxhighlight> → {{pos|6.51|4.32|2.13}}
Supplying inaccurate coordinates (not using two decimals) will produce an error underline to make them easy to spot:
<syntaxhighlight lang="wikitext" inline>{{coords|1|2|3}}</syntaxhighlight> → {{coords|1|2|3}}
Inaccurate coordinates will also cause the page to be placed in the [[:Category:Pages with inaccurate coordinates|Pages with inaccurate coordinates]] category.
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
1b24fae93c6fb22ca98e821fc62e95f40a446b69
File:Debug overlay.png
6
962
1608
2025-09-13T01:29:43Z
Sharparam
284703
The in-game debug overlay that can be enabled by using the <code>showdebug</code> command in the game console (needs to be enabled by using third party software).
wikitext
text/x-wiki
== Summary ==
The in-game debug overlay that can be enabled by using the <code>showdebug</code> command in the game console (needs to be enabled by using third party software).
== Licensing ==
{{License|fairuse}}
bf93d80c9806753c0bce5323007139846ee91c0e
Template:Infobox/Ring
10
561
1610
877
2025-09-13T01:45:19Z
Sharparam
284703
Add support for effects and passives
wikitext
text/x-wiki
<includeonly>{{#invoke:infobox|main
| kind = ring
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| Sections=Basic Info
| Basic Info=Effects,Passives
| Effects={{#if:{{{Effects|}}}|{{Plainlist|{{{Effects}}}}}}}
| Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
}}{{Main other|[[Category:Rings]]}}</includeonly><noinclude>{{Documentation}}</noinclude>
3216156e4f850ffffa176342fb8fd0a2c2b55210
1612
1610
2025-09-13T01:47:16Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
<includeonly>{{#invoke:infobox|main
| kind = ring
| title = {{{title|{{PAGENAME}}}}}
| image = {{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
| sections=Basic Info
| Basic Info=Effects, Passives
| Effects={{#if:{{{Effects|}}}|{{Plainlist|{{{Effects}}}}}}}
| Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
}}{{Main other|[[Category:Rings]]}}</includeonly><noinclude>{{Documentation}}</noinclude>
ac580d6ab5e3fb231fe6dee5e41ff2297a30b684
Template:Infobox/Ring/doc
10
562
1611
878
2025-09-13T01:46:34Z
Sharparam
284703
Update example
wikitext
text/x-wiki
== Example ==
{{Infobox/Ring
| title = Cool Ring
| image = Cool Ring.png
| Effects =
* Some effect
* Does other stuff too
| Passives = Strength bonus,Agility bonus
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Ring
| title = Cool Ring
| image = Cool Ring.png
| Effects =
* Some effect
* Does other stuff too
| Passives = Strength bonus,Agility bonus
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
8a4e5bff7d362ec2209b352f048754f127bea8d4
1628
1611
2025-09-13T02:06:00Z
Sharparam
284703
Use rammstein ring for example
wikitext
text/x-wiki
== Example ==
{{Infobox/Ring
| title = Cool Ring
| image = Ring of Rammstein (ring).png
| Effects =
* Some effect
* Does other stuff too
| Passives = Strength bonus,Agility bonus
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Ring
| title = Cool Ring
| image = Ring of Rammstein (ring).png
| Effects =
* Some effect
* Does other stuff too
| Passives = Strength bonus,Agility bonus
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
d138ac5857a2fa2afd11b240ee5a1298eedfb6c7
Ring of Burning Desire
0
519
1613
802
2025-09-13T01:49:29Z
Sharparam
284703
Add effect, update file name
wikitext
text/x-wiki
{{Infobox/Ring
| image = Ring of Burning Desire (ring).png
| title = {{PAGENAME}}
| Effects = * +20% chance to inflict [[Heat|Heat status effect]]
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] that can be found in {{BFF}}.
== Acquisition ==
Drops from [[Diver]] [[enemies]] in [[Deluge|the Deluge]] area.
{{Navbox/Rings}}
79d408a95afaad8989b7041980f3a858c86d3087
File:Ring of Burning Desire (ring).png
6
963
1614
2025-09-13T01:50:45Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_37
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_37
}}
== Licensing ==
{{License|game}}
7665ed47d5c799784e86fb0e18c8435cdf155c0e
Ring of Casting Speed
0
520
1615
804
2025-09-13T01:52:17Z
Sharparam
284703
Update effects and image name
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Casting Speed (ring).png
| Effects =
* -10% attack power
* +20% technocasting speed
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Acquisition ==
Drops from a giant enemy in [[Uranopolis]], around {{coords|-1151|-4475|1453}}.
{{Navbox/Rings}}
b63998c2b57c5f3608675a0c28e564d0b388c0aa
File:Ring of Casting Speed (ring).png
6
964
1616
2025-09-13T01:52:54Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_34
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_34
}}
== Licensing ==
{{License|game}}
fcbdab131e1d2c09f171516349b8cd15e3d123a6
Ring of Rammstein
0
521
1617
806
2025-09-13T01:53:31Z
Sharparam
284703
Update passives and image name
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Rammstein (ring).png
| Passives = Momentum Strike
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Location ==
{{main|Tech Shield#Location}}
This item is located on the same corpse as the [[Tech Shield]].
{{Navbox/Rings}}
1fcd9923fe535740cede487369bdd10cdd73cd43
File:Ring of Rammstein (ring).png
6
965
1618
2025-09-13T01:54:21Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_90
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_90
}}
== Licensing ==
{{License|game}}
830f2d79c7781f398fc28bca0f9dae31ff04207a
Ring of Serpent
0
748
1619
1157
2025-09-13T01:55:03Z
Sharparam
284703
Update effects, passives, and image name
wikitext
text/x-wiki
{{Infobox/Ring
| image = Ring of Serpent (ring).png
| title = {{PAGENAME}}
| Passives = Swift Reflexes
| Effects = * +2 [[Agility]]
}}
== Location ==
Near one of the underwater red lights in [[Deluge]].
{{Navbox/Rings}}
d59a9f1f8977fd40fc8b976d3c2891c5e480ffd4
File:Ring of Serpent (ring).png
6
966
1620
2025-09-13T01:56:05Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_88
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_88
}}
== Licensing ==
{{License|game}}
6a44f24fa8ecc46c8b1d586f45e3f01690696384
Ring of Exceeding Talent
0
522
1621
808
2025-09-13T01:56:58Z
Sharparam
284703
Update effects and image name
wikitext
text/x-wiki
{{Infobox/Ring
| title = {{PAGENAME}}
| image = Ring of Exceeding Talent (ring).png
| Effects =
* +3 [[Strength]]
* +3 [[Agility]]
* +3 [[Constitution]]
* +3 [[Intelligence]]
}}
'''{{PAGENAME}}''' is a [[Rings|ring]] in {{BFF}}.
== Location ==
{{coords|3720|1159|-1397}}
Located in the [[Desert]] on a toppled pillar in the area with Yaroslav's crew (same location as the [[Handler Echo]]).
== See also ==
* [[Ring of Lesser Talent]] – The weakest version of this ring.
* [[Ring of Talent]] – A weaker version of this ring.
{{Navbox/Rings}}
a0b746136c3347050b18c4b0b95e7851eab96532
File:Ring of Exceeding Talent (ring).png
6
967
1622
2025-09-13T01:57:49Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_100
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyRings/256x256/fantasyRing_100
}}
== Licensing ==
{{License|game}}
4cd7d1e578ba59fdab07b4448f547e3a1f2aeea4
Template:Infobox/Ability/doc
10
460
1623
685
2025-09-13T01:59:19Z
Sharparam
284703
Use an existing image for example
wikitext
text/x-wiki
== Example ==
{{Infobox/Ability
|image=OrientalDash.png
|title=Shoot Star
|Description=Shoots a star.
|Cost=50
|Cooldown=12
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Ability
|image=OrientalDash.png
|title=Shoot Star
|Description=Shoots a star.
|Cost=50
|Cooldown=12
}}
</syntaxhighlight>
59c35e2e2d842e289e5c521db8c65cd5f786843e
Momentum Strike
0
968
1624
2025-09-13T02:02:35Z
Sharparam
284703
Created page with "{{Infobox/Passive | image = Momentum Strike (passive).png | Description = Rolling deals damage basead on [[Strength]] in a circle around you. Can only be activated once every {{Duration|s=30|display=30 seconds}}. }} '''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}. {{Navbox/Passives}}"
wikitext
text/x-wiki
{{Infobox/Passive
| image = Momentum Strike (passive).png
| Description = Rolling deals damage basead on [[Strength]] in a circle around you. Can only be activated once every {{Duration|s=30|display=30 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
6f77a86032f42bde0253c72b06e37cf937ad5997
1627
1624
2025-09-13T02:04:59Z
Sharparam
284703
Fix image
wikitext
text/x-wiki
{{Infobox/Passive
| image = Universal Passive.png
| Description = Rolling deals damage basead on [[Strength]] in a circle around you. Can only be activated once every {{Duration|s=30|display=30 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
ab3923bb3223ec689cca90eefb31473bbf59c02c
Template:Navbox/Passives
10
838
1625
1314
2025-09-13T02:02:52Z
Sharparam
284703
Add [[Momentum Strike]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Passives
| title = [[Passives]]
| list =
* [[Momentum Strike]]
* [[Vulnerable Dodge]]
}}<noinclude>{{Documentation}}</noinclude>
21ab89b7493ffa70b704f538de819b449133f146
Template:Infobox/Passive/doc
10
836
1626
1312
2025-09-13T02:04:40Z
Sharparam
284703
Use universal passive icon in example
wikitext
text/x-wiki
== Examples ==
{{Infobox/Passive
| title = Example Passive
| image = Universal Passive.png
| Description = Increases your stats to ungodly amounts.
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Passive
| title = Example Passive
| image = Universal Passive.png
| Description = Increases your stats to ungodly amounts.
}}
</syntaxhighlight>
<includeonly>{{Sandbox other||[[Category:Infobox templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
0b3d42797f0fac836341e748789c732f7c7e63ef
Template:Infobox/Shield/doc
10
458
1629
681
2025-09-13T02:06:35Z
Sharparam
284703
Use wooden shield image for example
wikitext
text/x-wiki
== Examples ==
{{Infobox/Shield
| image = Wooden Shield.png
| title = Test Shield
| Weight = Light
| Abilities = Shield Bash
| Mk0_Sharp = 10
| Mk0_Blunt = 10
| Mk0_Technomancy = 10
| Mk1_Sharp = 20
| Mk1_Blunt = 20
| Mk1_Technomancy = 20
| Mk2_Sharp = 30
| Mk2_Blunt = 30
| Mk2_Technomancy = 30
| Mk3_Sharp = 40
| Mk3_Blunt = 40
| Mk3_Technomancy = 40
| Mk4_Sharp = 50
| Mk4_Blunt = 50
| Mk4_Technomancy = 50
| Mk5_Sharp = 60
| Mk5_Blunt = 60
| Mk5_Technomancy = 60
}}
<syntaxhighlight lang="wikitext">
{{Infobox/Shield
| image = Wooden Shield.png
| title = Test Shield
| Weight = Light
| Abilities = Shield Bash
| Mk0_Sharp = 10
| Mk0_Blunt = 10
| Mk0_Technomancy = 10
| Mk1_Sharp = 20
| Mk1_Blunt = 20
| Mk1_Technomancy = 20
| Mk2_Sharp = 30
| Mk2_Blunt = 30
| Mk2_Technomancy = 30
| Mk3_Sharp = 40
| Mk3_Blunt = 40
| Mk3_Technomancy = 40
| Mk4_Sharp = 50
| Mk4_Blunt = 50
| Mk4_Technomancy = 50
| Mk5_Sharp = 60
| Mk5_Blunt = 60
| Mk5_Technomancy = 60
}}
</syntaxhighlight>
3b54a1bdb8c7ec0d368ca9b9da5433b3a64ec131
Basilisk Hack
0
969
1630
2025-09-13T15:16:45Z
Sharparam
284703
Created page with "{{Infobox/Item | type = consumable | image = Basilisk Hack (item).png | Description = Reset all of your assigned [[attributes]]. Usable from inventory. }} '''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}. == Manufacturing == {{Recipe | type = manufacturing | result = Basilisk Hack | ingredient1 = Sludge | ingredient1_count = 20 | ingredient2 = Fractal Fungus | ingredient3 = Essence | ingredient3_count = 6 }} {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Infobox/Item
| type = consumable
| image = Basilisk Hack (item).png
| Description = Reset all of your assigned [[attributes]]. Usable from inventory.
}}
'''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}.
== Manufacturing ==
{{Recipe
| type = manufacturing
| result = Basilisk Hack
| ingredient1 = Sludge
| ingredient1_count = 20
| ingredient2 = Fractal Fungus
| ingredient3 = Essence
| ingredient3_count = 6
}}
{{Navbox/Consumables}}
c8b7962143a466248652806ae936bdcbebcda643
File:Basilisk Hack (item).png
6
970
1631
2025-09-13T15:17:18Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_47
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_47
}}
== Licensing ==
{{License|game}}
e38ad62164ab71347496c696676ecf82203c1d0a
Glowbug
0
971
1632
2025-09-13T15:18:52Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = consumable | image = Glowbug (item).png | Description = A glow effect around character, allowing you to see better for {{Duration|s=120|display=120 seconds}}. }} '''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}. {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = consumable
| image = Glowbug (item).png
| Description = A glow effect around character, allowing you to see better for {{Duration|s=120|display=120 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}.
{{Navbox/Consumables}}
0075e7ef04cfeaee9e5c07b3d4e1bfc4c9099223
File:Glowbug (item).png
6
972
1633
2025-09-13T15:19:21Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/glowbug
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/glowbug
}}
== Licensing ==
{{License|game}}
c9c9426eae039f67be080bcb326ba46188ab6c7e
Metal Arrow Pack
0
973
1634
2025-09-13T15:21:33Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = consumable | image = Metal Arrow Pack (item).png | Description = Adds 9 [[Metal Arrows|metal arrows]] to your quiver. Any arrows that can't fit in the quiver will be placed in the backpack instead. }} '''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}. == Crafting == {{Recipe | result = Metal Arrow Pack | ingredient1 = Metal Arrows | ingredient1_count = 9 | ingredient2 = Machinite }} {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = consumable
| image = Metal Arrow Pack (item).png
| Description = Adds 9 [[Metal Arrows|metal arrows]] to your quiver. Any arrows that can't fit in the quiver will be placed in the backpack instead.
}}
'''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Metal Arrow Pack
| ingredient1 = Metal Arrows
| ingredient1_count = 9
| ingredient2 = Machinite
}}
{{Navbox/Consumables}}
05ea3953bc77dff9a02beb98f629b48576b0ccd6
File:Metal Arrow Pack (item).png
6
974
1635
2025-09-13T15:21:58Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/icon_quiver2
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/icon_quiver2
}}
== Licensing ==
{{License|game}}
b4a0afb98f7a8c94da4914c6b30f8817637988ac
Piercing Arrow Pack
0
975
1636
2025-09-13T15:23:50Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = consumable | image = Piercing Arrow Pack (item).png | Description = Adds 9 [[Piercing Arrow|piercing arrows]] to your quiver. Any arrows that can't fit in the quiver will be placed in the backpack instead. }} '''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}. == Crafting == {{Recipe | result = Piercing Arrow Pack | ingredient1 = Piercing Arrow | ingredient1_count = 9 | ingredient2 = Machinite }} {{Navbox/Consumabl..."
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = consumable
| image = Piercing Arrow Pack (item).png
| Description = Adds 9 [[Piercing Arrow|piercing arrows]] to your quiver. Any arrows that can't fit in the quiver will be placed in the backpack instead.
}}
'''{{PAGENAME}}''' is a [[Consumables|consumable]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Piercing Arrow Pack
| ingredient1 = Piercing Arrow
| ingredient1_count = 9
| ingredient2 = Machinite
}}
{{Navbox/Consumables}}
18bd2d324394484b889ede1c2e02ac6e80fb0bb1
File:Piercing Arrow Pack (item).png
6
976
1637
2025-09-13T15:24:14Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/icon_quiver1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/icon_quiver1
}}
== Licensing ==
{{License|game}}
8417858eba552ceb85e1329362a2e88381c6981c
Piercing Arrow
0
822
1638
1277
2025-09-13T15:26:03Z
Sharparam
284703
Add crafting recipes
wikitext
text/x-wiki
{{Infobox/Item
| image = Piercing Arrow.png
| type = ammunition
| Description = A projectile that ignores up to 2000 armor rating.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Piercing Arrow
| result_count = 6
| ingredient1 = Machinite
| ingredient1_count = 2
| ingredient2 = Gravicle Dust
}}
{{Recipe
| result = Piercing Arrow
| result_count = 6
| ingredient1 = Metal Arrows
| ingredient1_count = 6
| ingredient2 = Gravicle Dust
}}
{{Navbox/Ammunition}}
{{Navbox/Longbows|state=collapsed}}
5422c1108397ac11f50f4553bf562d2cabc2eebf
Metal Arrows
0
816
1639
1272
2025-09-13T15:27:17Z
Sharparam
284703
Add crafting recipes
wikitext
text/x-wiki
{{Infobox/Item
| image = Metal Arrows.png
| type = ammunition
| Description = A common and replaceable projectile.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Metal Arrows
| result_count = 6
| ingredient = Machinite
| ingredient_count = 2
}}
{{Recipe
| result = Metal Arrows
| result_count = 2
| ingredient = Broken Arrow
| ingredient_count = 3
}}
{{Navbox/Ammunition}}
{{Navbox/Longbows|state=collapsed}}
c7ff9c78c44a27cd62bd990ded25c5f30680e677
Shock Arrows
0
824
1640
1279
2025-09-13T15:28:38Z
Sharparam
284703
Add crafting recipes
wikitext
text/x-wiki
{{Infobox/Item
| image = Shock Arrows.png
| type = ammunition
| Description = A projectile that stuns most enemies for {{Duration|s=7|display=7 seconds}}.
}}
'''{{PAGENAME}}''' is a type of [[ammunition]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Shock Arrows
| result_count = 3
| ingredient1 = Machinite
| ingredient2 = Neurilium
}}
{{Recipe
| result = Shock Arrows
| result_count = 3
| ingredient1 = Metal Arrows
| ingredient1_count = 3
| ingredient2 = Neurilium
}}
{{Navbox/Ammunition}}
{{Navbox/Longbows|state=collapsed}}
f0dfa24f23ccb001698fd264269f0acda2514236
Mystery Concoction
0
977
1641
2025-09-13T15:32:10Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = concoction | image = Mystery Concoction (item).png | Description = Drink me. }} '''{{PAGENAME}}''' is a [[Concoctions|concoction]] in {{BFF}}. == Manufacturing == {{Recipe | result = Mystery Concoction | ingredient = Sludge | ingredient_count = 12 }} {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = concoction
| image = Mystery Concoction (item).png
| Description = Drink me.
}}
'''{{PAGENAME}}''' is a [[Concoctions|concoction]] in {{BFF}}.
== Manufacturing ==
{{Recipe
| result = Mystery Concoction
| ingredient = Sludge
| ingredient_count = 12
}}
{{Navbox/Consumables}}
2a859fcaf6c5e49d96ccf4645792c4b0abfec701
1644
1641
2025-09-13T15:35:54Z
Sharparam
284703
Add monastery location
wikitext
text/x-wiki
{{Infobox/Item
| type = concoction
| image = Mystery Concoction (item).png
| Description = Drink me.
}}
'''{{PAGENAME}}''' is a [[Concoctions|concoction]] in {{BFF}}.
== Locations ==
=== [[Monastery]] ===
{{Needs coordinates|tiny=yes|what=This section}}
One can be found at the start of the game, behind where the player spawns in after the intro cutscene.
== Manufacturing ==
{{Recipe
| result = Mystery Concoction
| ingredient = Sludge
| ingredient_count = 12
}}
{{Navbox/Consumables}}
883b64cf5d1dfb02faab81245e8a1108ce91f979
Template:Navbox/Consumables
10
286
1642
1306
2025-09-13T15:32:37Z
Sharparam
284703
Remove mystery concoction from fluid list
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Consumables
| title = [[Consumables]]
| list1 =
* [[Asylum Brew]]
* [[Basilisk Hack]]
* [[Glowbug]]
* [[Metal Arrow Pack]]
* [[Piercing Arrow Pack]]
| group2 = [[Fluids]]
| list2 =
* [[Ionization Fluid]]
** [[Lesser Ionization Fluid|Lesser]]
** [[Greater Ionization Fluid|Greater]]
* [[Regenerative Fluid]]
** [[Greater Regenerative Fluid|Greater]]
* [[Restorative Fluid]]
** [[Lesser Restorative Fluid|Lesser]]
** [[Greater Restorative Fluid|Greater]]
| group3 = [[Concoctions]]
| list3 =
* [[Diver's Lungs Concoction]]
** [[Improved Diver's Lungs Concoction|Improved]]
* [[Dreadguard's Concoction]]
** [[Greater Dreadguard's Concoction|Greater]]
* [[Experience Concoction]]
* [[Fluxshield Concoction]]
* [[Forsaken Concoction]]
** [[Greater Forsaken Concoction|Greater]]
* [[Indestructible Concoction]]
* [[Jaeger's Concoction]]
** [[Greater Jaeger's Concoction|Greater]]
* [[Mystery Concoction]]
* [[Stoneshield Concoction]]
* [[Spongeskin Concoction]]
* [[Technomancer's Concoction]]
** [[Greater Technomancer's Concoction|Greater]]
* [[Concoction: Aberrant's Blood]]
* [[Concoction: Agility]]
* [[Concoction: All Attributes]]
* [[Concoction: Berserker's Tenacity]]
* [[Concoction: Constitution]]
* [[Concoction: Flux Regen]]
* [[Concoction: Health Regen]]
* [[Concoction: Intelligence]]
* [[Concoction: Mighty Regen]]
* [[Concoction: Powerful Immune System]]
* [[Concoction: Rapid Recovery]]
* [[Concoction: Strength]]
* [[Concoction: Zealot's Tears]]
}}<noinclude>[[Category:Navigation templates]]</noinclude>
25a77ebb77b38a0a394a21d17595b28ef884824b
File:Mystery Concoction (item).png
6
978
1643
2025-09-13T15:33:24Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_4
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/FantasyPotions/256x256/FantasyPotion_4
}}
== Licensing ==
{{License|game}}
6b6767922e588486008db577835f98663ee80637
Regenerative Fluid
0
979
1645
2025-09-13T15:37:42Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = fluid | image = Regenerative Fluid (item).png | Description = Restores 50% of total [[health]] over {{Duration|s=10|display=10 seconds}}. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}. {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = fluid
| image = Regenerative Fluid (item).png
| Description = Restores 50% of total [[health]] over {{Duration|s=10|display=10 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}.
{{Navbox/Consumables}}
4ec3a2e7e6b6ca562d663998daf05f66fe8de140
File:Regenerative Fluid (item).png
6
980
1646
2025-09-13T15:38:22Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_37
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_37
}}
== Licensing ==
{{License|game}}
805cc410b5e368d7769d8c7a258757e28c562dba
Greater Regenerative Fluid
0
981
1647
2025-09-13T15:39:29Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = fluid | image = Greater Regenerative Fluid (item).png | Description = Restores 50% of total [[health]] over {{Duration|s=6|display=6 seconds}}. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}. {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = fluid
| image = Greater Regenerative Fluid (item).png
| Description = Restores 50% of total [[health]] over {{Duration|s=6|display=6 seconds}}.
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}.
{{Navbox/Consumables}}
034871580401f9046c0f5090e72c81d1c6cd7a87
File:Greater Regenerative Fluid (item).png
6
982
1648
2025-09-13T15:40:01Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_42
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_42
}}
== Licensing ==
{{License|game}}
108b798638cc22ec8f81545a19e46e34d7a8fb62
Restorative Fluid
0
983
1649
2025-09-13T15:45:05Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = fluid | image = Restorative Fluid (item).png | Description = A terribly potent concoction used to regenerate lost tissue. Restores 450 [[Health]]. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}. == Crafting == {{Recipe | result = Restorative Fluid | ingredient1 = Sludge | ingredient1_count = 2 | ingredient2 = Gingko Leaves | ingredient2_count = 2 }} {{Recipe | result = Restorative Fluid | ingredient1 = Lesser Restorat..."
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = fluid
| image = Restorative Fluid (item).png
| Description = A terribly potent concoction used to regenerate lost tissue. Restores 450 [[Health]].
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Restorative Fluid
| ingredient1 = Sludge
| ingredient1_count = 2
| ingredient2 = Gingko Leaves
| ingredient2_count = 2
}}
{{Recipe
| result = Restorative Fluid
| ingredient1 = Lesser Restorative Fluid
| ingredient1_count = 2
| ingredient2 = Gingko Leaves
}}
== Trivia ==
* The description refers to it as a concoction, despite both the name and in-game categorization using <q>fluid</q>.
{{Navbox/Consumables}}
5a9d8320e23ba4359ece370a2e00dfe45a21f84e
File:Restorative Fluid (item).png
6
984
1650
2025-09-13T15:45:34Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_75
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_75
}}
== Licensing ==
{{License|game}}
b82b273f2ea2ce0e864477a49442b22fa671c1af
Lesser Restorative Fluid
0
985
1651
2025-09-13T15:46:55Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = fluid | image = Lesser Restorative Fluid (item).png | Description = A terribly potent concoction used to regenerate lost tissue. Restores 225 [[Health]]. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}. == Crafting == {{Recipe | result = Lesser Restorative Fluid | ingredient1 = Sludge | ingredient2 = Gingko Leaves }} {{Navbox/Consumables}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = fluid
| image = Lesser Restorative Fluid (item).png
| Description = A terribly potent concoction used to regenerate lost tissue. Restores 225 [[Health]].
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Lesser Restorative Fluid
| ingredient1 = Sludge
| ingredient2 = Gingko Leaves
}}
{{Navbox/Consumables}}
5af7ba971fd8e21a39ba0187ce109175def7691e
File:Lesser Restorative Fluid (item).png
6
986
1652
2025-09-13T15:47:24Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_84
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_84
}}
== Licensing ==
{{License|game}}
0db0ef78c90ef2a454f33f9f1f65a8033c04fc0a
Greater Restorative Fluid
0
987
1653
2025-09-13T15:49:15Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Item | type = fluid | image = Greater Restorative Fluid (item).png | Description = A terribly potent concoction used to regenerate lost tissue. Restores 850 [[Health]]. }} '''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}. == Crafting == {{Recipe | result = Greater Restorative Fluid | ingredient1 = Sludge | ingredient1_count = 3 | ingredient2 = Gingko Leaves | ingredient2_count = 3 }} {{Recipe | result = Greater Restorative Fluid | ingre..."
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Item
| type = fluid
| image = Greater Restorative Fluid (item).png
| Description = A terribly potent concoction used to regenerate lost tissue. Restores 850 [[Health]].
}}
'''{{PAGENAME}}''' is a [[Fluids|fluid]] in {{BFF}}.
== Crafting ==
{{Recipe
| result = Greater Restorative Fluid
| ingredient1 = Sludge
| ingredient1_count = 3
| ingredient2 = Gingko Leaves
| ingredient2_count = 3
}}
{{Recipe
| result = Greater Restorative Fluid
| ingredient1 = Restorative Fluid
| ingredient1_count = 2
| ingredient2 = Gingko Leaves
}}
{{Navbox/Consumables}}
e15a707e7c10201f6df25e53bbb3314ceb4b126b
File:Greater Restorative Fluid (item).png
6
988
1654
2025-09-13T15:49:38Z
Sharparam
284703
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_89
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/Resources/ClassicPotions/256x256/ClassicPotion_89
}}
== Licensing ==
{{License|game}}
14d11b68bcc8f2ec0ce187a9cdf3be8a093e25f3
Armor Buster
0
989
1655
2025-09-13T15:52:14Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Armor Buster (weapon).png | Type = Greatweapon | Speed = Sluggish | Damage type = Blunt | Passives = Armor Buster (passive) | Mk_min = 2 | Mk2_Damage_min = 338 | Mk2_Damage_max = 354 }} '''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Armor Buster (weapon).png
| Type = Greatweapon
| Speed = Sluggish
| Damage type = Blunt
| Passives = Armor Buster (passive)
| Mk_min = 2
| Mk2_Damage_min = 338
| Mk2_Damage_max = 354
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
{{Navbox/Weapons}}
1c6724ef7c97bed7971e0036d019b2222e7fa5c8
1662
1655
2025-09-13T15:57:57Z
Sharparam
284703
Fix passive
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Armor Buster (weapon).png
| Type = Greatweapon
| Speed = Sluggish
| Damage type = Blunt
| Passives = Armor Buster
| Mk_min = 2
| Mk2_Damage_min = 338
| Mk2_Damage_max = 354
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
{{Navbox/Weapons}}
570b9f9c629465acf94664dfe540475a410b1428
Template:Infobox/Weapon
10
451
1656
1578
2025-09-13T15:53:21Z
Sharparam
284703
Add support for greatweapons
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| pattern = * [[@@@@]]
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| template = Ability link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| greatweapon = [[Greatweapons|Greatweapon]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| greatweapon = [[Category:Greatweapons]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| greatweapon = greatweapon
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
0f2366cccf831534d1e0ac0c1765b8cdb35d6561
1661
1656
2025-09-13T15:57:33Z
Sharparam
284703
Use template for passive links
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| template = Passive link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| template = Ability link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| greatweapon = [[Greatweapons|Greatweapon]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| greatweapon = [[Category:Greatweapons]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{{title|}}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| greatweapon = greatweapon
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
6929e21a60cf53738335a0c32200966615678841
Template:Passive link
10
990
1657
2025-09-13T15:54:20Z
Sharparam
284703
Created page with "{{#switch:{{{1}}} | Armor Buster = [[Armor Buster (passive)|Armor Buster]] | #default = [[{{{1}}}]] }}<!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#switch:{{{1}}}
| Armor Buster = [[Armor Buster (passive)|Armor Buster]]
| #default = [[{{{1}}}]]
}}<!--
--><noinclude>{{Documentation}}</noinclude>
72eaff1bc43a162efe03cce838bee85d1fa38e37
Template:Passive link/doc
10
991
1658
2025-09-13T15:56:11Z
Sharparam
284703
Created page with "Used to produce a link to a [[Passives|passive]]. This is primarily useful to automatically handle cases where a passive shares a name with some other page, in which case the article for the passive is usually named with a " (passive)" suffix. == TemplateData == <templatedata> { "params": { "1": { "label": "Passive", "description": "The passive to link to", "example": "Armor Buster", "type": "line", "required": true } }, "description": "Generate a..."
wikitext
text/x-wiki
Used to produce a link to a [[Passives|passive]].
This is primarily useful to automatically handle cases where a passive shares a name with some other page, in which case the article for the passive is usually named with a " (passive)" suffix.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Passive",
"description": "The passive to link to",
"example": "Armor Buster",
"type": "line",
"required": true
}
},
"description": "Generate a link to a passive.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Passive link|Heavy Hitter}}</syntaxhighlight> → {{Ability link|Heavy Hitter}}
* <syntaxhighlight lang="wikitext" inline>{{Passive link|Armor Buster}}</syntaxhighlight> → {{Passive link|Armor Buster}}
Note how in the "Armor Buster" example, the link goes to "Armor Buster (passive)" without having to specify it manually.
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
99f3b51e24ae072ac18d9ffecb649e0362fb082a
Template:Passive link item
10
992
1659
2025-09-13T15:56:44Z
Sharparam
284703
Created page with "* {{Passive link|{{{1}}}}}<!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
* {{Passive link|{{{1}}}}}<!--
--><noinclude>{{Documentation}}</noinclude>
b3c13eb46479c7c5c03f244659f654527f06f391
Template:Passive link item/doc
10
993
1660
2025-09-13T15:57:03Z
Sharparam
284703
Created page with "Used in [[:Category:Infobox templates|infobox templates]] for passive link lists. Not intended for usage elsewhere. <includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly> <noinclude>[[Category:Template documentation]]</noinclude>"
wikitext
text/x-wiki
Used in [[:Category:Infobox templates|infobox templates]] for passive link lists. Not intended for usage elsewhere.
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly>
<noinclude>[[Category:Template documentation]]</noinclude>
0a673de692e0447983054a6ea6c66e98bdf2045e
File:Armor Buster (weapon).png
6
994
1663
2025-09-13T15:59:02Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_ArmorBuster
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_ArmorBuster
}}
== Licensing ==
{{License|game}}
40690993aaa408ba8201c628b9f11022580d9b60
Eviscerator
0
995
1664
2025-09-13T16:00:57Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Eviscerator (weapon).png | Type = Greatweapon | Speed = Sluggish | Damage type = Blunt | Abilities = Expose Armor, Berserking Leap | Mk_min = 3 | Mk3_Damage_min = 406 | Mk3_Damage_max = 425 }} '''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Eviscerator (weapon).png
| Type = Greatweapon
| Speed = Sluggish
| Damage type = Blunt
| Abilities = Expose Armor, Berserking Leap
| Mk_min = 3
| Mk3_Damage_min = 406
| Mk3_Damage_max = 425
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
{{Navbox/Weapons}}
7cb927045a3dc22df2c45efeb4185c94495174dc
File:Eviscerator (weapon).png
6
996
1665
2025-09-13T16:01:25Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Eviscerator
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_Eviscerator
}}
== Licensing ==
{{License|game}}
41a949e066e9b98b46f6b36d57cf47a6bd532b19
Greathammer
0
997
1666
2025-09-13T16:02:53Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Greathammer (weapon).png | Type = Greatweapon | Speed = Sluggish | Damage type = Blunt | Passives = Bash, Pestilence | Mk_min = 2 | Mk2_Damage_min = 338 | Mk2_Damage_max = 354 }} '''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Greathammer (weapon).png
| Type = Greatweapon
| Speed = Sluggish
| Damage type = Blunt
| Passives = Bash, Pestilence
| Mk_min = 2
| Mk2_Damage_min = 338
| Mk2_Damage_max = 354
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
{{Navbox/Weapons}}
8ef5d4e7b02b0f3e48ab9e0d6b072084519e10c1
File:Greathammer (weapon).png
6
998
1667
2025-09-13T16:03:26Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_HeavyMace
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_HeavyMace
}}
== Licensing ==
{{License|game}}
107d30d1dfb1a99456891d05464cd541f67fdb9c
Titan Slayer Greatsword
0
999
1668
2025-09-13T16:05:04Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Titan Slayer Greatsword (weapon).png | Type = Greatweapon | Speed = Sluggish | Damage type = Sharp | Abilities = Guillotine, Downward Slash | Mk_min = 3 | Mk3_Damage_min = 312 | Mk3_Damage_max = 343 }} '''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Titan Slayer Greatsword (weapon).png
| Type = Greatweapon
| Speed = Sluggish
| Damage type = Sharp
| Abilities = Guillotine, Downward Slash
| Mk_min = 3
| Mk3_Damage_min = 312
| Mk3_Damage_max = 343
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
{{Navbox/Weapons}}
daa2b889a37d2be9992ceb862e00a9a17236bec6
File:Titan Slayer Greatsword (weapon).png
6
1000
1669
2025-09-13T16:05:31Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_TitanSlayer
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_TitanSlayer
}}
== Licensing ==
{{License|game}}
ba7d88ced1e0fc8bf7d279a4bd43be5a0de28ede
Armor Buster (passive)
0
1001
1670
2025-09-13T16:07:13Z
Sharparam
284703
Created page with "{{Infobox/Passive | image = Universal Passive.png | Description = Your melee attacks ignore 50% of target's current Armor Ratings. }} {{Navbox/Passives}}"
wikitext
text/x-wiki
{{Infobox/Passive
| image = Universal Passive.png
| Description = Your melee attacks ignore 50% of target's current Armor Ratings.
}}
{{Navbox/Passives}}
8a8234e6e36bcfee142b3ce41798020b82fb993c
1671
1670
2025-09-13T16:07:35Z
Sharparam
284703
Add intro text
wikitext
text/x-wiki
{{Infobox/Passive
| image = Universal Passive.png
| Description = Your melee attacks ignore 50% of target's current Armor Ratings.
}}
'''Armor Buster''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
5f726a12a6803a7b9dd201a555f9334063ac7642
Template:Navbox/Passives
10
838
1672
1625
2025-09-13T16:08:02Z
Sharparam
284703
Add armor buster
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Passives
| title = [[Passives]]
| list =
* [[Armor Buster (passive)|Armor Buster]]
* [[Momentum Strike]]
* [[Vulnerable Dodge]]
}}<noinclude>{{Documentation}}</noinclude>
2c3e5ca88cb446ba671569d4c26691e692200b8e
1674
1672
2025-09-13T16:10:16Z
Sharparam
284703
Add [[Greater Divine Judgement]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Passives
| title = [[Passives]]
| list =
* [[Armor Buster (passive)|Armor Buster]]
* [[Greater Divine Judgement]]
* [[Momentum Strike]]
* [[Vulnerable Dodge]]
}}<noinclude>{{Documentation}}</noinclude>
724953fa74861005357e3d004c1c121959e1e66e
1684
1674
2025-09-13T16:34:08Z
Sharparam
284703
Add missing passives
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Passives
| title = [[Passives]]
| list =
* [[Armor Buster (passive)|Armor Buster]]
* [[Bash]]
* [[Bloodthirst]]
* [[Consistent Strikes]]
* [[Critical Strike (passive)|Critical Strike]]
* [[Experience Amplification]]
* [[Experience Suppression]]
* [[Extended Evasion]]
* [[Flux Efficiency]]
* [[Giant Slayer]]
* [[Greater Divine Judgement]]
* [[Heavy Hitter]]
* [[Lacerate]]
* [[Lifesteal (passive)|Lifesteal]]
* [[Minor Flux Regen]]
* [[Momentum Strike]]
* [[Muscle Mastery]]
* [[Pestilence]]
* [[Powerful Decay]]
* [[Rapid Fire]]
* [[Scavenger's Rejuvenation]]
* [[Serene Movement]]
* [[Spare Shot]]
* [[Spikes]]
* [[Summoning Extension]]
* [[Survivor's Wisdom]]
* [[Swift Reflexes]]
* [[Techno-Defiance]]
* [[Universal Judgment]]
* [[Vermillion Judgment]]
* [[Vitality Boost]]
* [[Volatile Illusions]]
* [[Vulnerable Dodge]]
}}<noinclude>{{Documentation}}</noinclude>
553ac93a26aa364ed2abcef924832eed24267f25
Greater Divine Judgement
0
1002
1673
2025-09-13T16:09:57Z
Sharparam
284703
Created page with "{{Infobox/Passive | image = Universal Passive.png | Description = Deals an extra 24% damage against all non-regular/forsaken [[enemies]]. }} '''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}. {{Navbox/Passives}}"
wikitext
text/x-wiki
{{Infobox/Passive
| image = Universal Passive.png
| Description = Deals an extra 24% damage against all non-regular/forsaken [[enemies]].
}}
'''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
af3ce6e544ce2a64b0b374250369db83e90c1c10
1675
1673
2025-09-13T16:10:47Z
Sharparam
284703
Sharparam renamed page [[Greater Divine Judgment]] to [[Greater Divine Judgement]] without leaving a redirect: Misspelled title
wikitext
text/x-wiki
{{Infobox/Passive
| image = Universal Passive.png
| Description = Deals an extra 24% damage against all non-regular/forsaken [[enemies]].
}}
'''{{PAGENAME}}''' is a [[Passives|passive]] in {{BFF}}.
{{Navbox/Passives}}
af3ce6e544ce2a64b0b374250369db83e90c1c10
Divine Greataxe
0
470
1676
705
2025-09-13T16:11:11Z
Sharparam
284703
Fix typo in passive
wikitext
text/x-wiki
{{Infobox/Weapon
| title = {{PAGENAME}}
| image = Divine Greataxe.png
| Type = Greatweapon
| Damage type = Sharp
| Speed = Sluggish
| Passives = Greater Divine Judgement
| Abilities = Regal Radiance
| Mk4_Damage_min = 597
| Mk4_Damage_max = 656
}}
'''{{PAGENAME}}''' is a [[Greatweapons|greatweapon]] in {{BFF}}.
== Location ==
{{coords|43210.37|165132.67|-141105.39}}
Found in the [[Anomaly]]. From the [[Homunculus]], walk past [[The Handler]] and you will see the item up ahead on the ledge of a building.
{{Navbox/Weapons}}
fc7e97560902df963b72533eeb4163cb50d05910
Regal Radiance
0
1003
1677
2025-09-13T16:13:23Z
Sharparam
284703
Created page with "{{Infobox/Ability | image = Regal Radiance (ability).png | Description = Increase your [[strength]] and [[constitution]] attribute based on your [[Intelligence]] Attribute for {{Duration|s=30|display=30 seconds}}. Blinds all nearby enemies, if enemy resist, instead daze them, reducing their attack power by 20%. | Cooldown = 60 | Cost = 150 }} '''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}. {{Navbox/Abilities}}"
wikitext
text/x-wiki
{{Infobox/Ability
| image = Regal Radiance (ability).png
| Description = Increase your [[strength]] and [[constitution]] attribute based on your [[Intelligence]] Attribute for {{Duration|s=30|display=30 seconds}}.
Blinds all nearby enemies, if enemy resist, instead daze them, reducing their attack power by 20%.
| Cooldown = 60
| Cost = 150
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
6a70f92d33cb0f33867d0b6a7aafb1966eeb7ba0
File:Regal Radiance (ability).png
6
1004
1678
2025-09-13T16:13:59Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_RegalRadiance
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_RegalRadiance
}}
== Licensing ==
{{License|game}}
8fd49abc02f7cbc260df7d3db0b6783e85eb9a26
Template:Navbox/Abilities
10
578
1679
1585
2025-09-13T16:14:29Z
Sharparam
284703
Add [[Regal Radiance]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = [[Abilities]]
| list1 =
* [[Blade Dash]]
* [[Bone Barrier]]
* [[Divine Blessing]]
* [[Marrow (ability)|Marrow]]
* [[Regal Radiance]]
* [[Whirlwind Strike]]
}}<noinclude>{{Documentation}}</noinclude>
6c71069be86888cd70026fcbb301f932195e426a
1681
1679
2025-09-13T16:17:02Z
Sharparam
284703
Add [[Blade Dance]]
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = [[Abilities]]
| list1 =
* [[Blade Dance]]
* [[Blade Dash]]
* [[Bone Barrier]]
* [[Divine Blessing]]
* [[Marrow (ability)|Marrow]]
* [[Regal Radiance]]
* [[Whirlwind Strike]]
}}<noinclude>{{Documentation}}</noinclude>
843b9adc8b38c5ad373ab1a65db53deee0f2adbf
1683
1681
2025-09-13T16:25:54Z
Sharparam
284703
Add missing abilities
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| template = Navbox/Abilities
| title = [[Abilities]]
| list1 =
* [[Aberrant Strike]]
* [[Arrow Brutality]]
* [[Arrow Twister]]
* [[Berserking Leap]]
* [[Blade Dance]]
* [[Blade Dash]]
* [[Blade Flurry]]
* [[Bladestorm]]
* [[Bone Barrier]]
* [[Carnage]]
* [[Charged Arrow]]
* [[Claymore Swing]]
* [[Crescent Slash]]
* [[Divine Blessing]]
* [[Downward Slash]]
* [[Dual Brutality]]
* [[Energy Burst]]
* [[Escape Velocity]]
* [[Expose Armor]]
* [[Forceful Repulsion]]
* [[Guillotine]]
* [[Heavy Strike]]
* [[Improvised Fortification]]
* [[Marrow (ability)|Marrow]]
* [[Mending Light]]
* [[Phase]]
* [[Pierce]]
* [[Premeditated Strike]]
* [[Quake]]
* [[Reanimate Dead]]
* [[Reap]]
* [[Refraction]]
* [[Regal Radiance]]
* [[Second Breath]]
* [[Shadowstep]]
* [[Shield Bash]]
* [[Silencing Reap]]
* [[Soul Storm]]
* [[Sword Strike]]
* [[Syphon Life]]
* [[Tornado]]
* [[Traitorous Leap]]
* [[Whiplash]]
* [[Whirlwind]]
* [[Whirlwind Strike]]
* [[Wind Blade]]
}}<noinclude>{{Documentation}}</noinclude>
7743f44a6560ec8baecdd2abc07d4eed7a43c661
Blade Dance
0
1005
1680
2025-09-13T16:16:42Z
Sharparam
284703
Created page with "{{Infobox/Ability | image = Blade Dance (ability).png | Description = Swing your weapon several times, dealing damage to all enemies in frontal cone. 46 damage and additional 34 from [[Agility]] attribute per instance of damage for a total of 320 [[Sharp]] damage. | Cooldown = 18 | Cost = 60 }} '''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}. {{Navbox/Abilities}}"
wikitext
text/x-wiki
{{Infobox/Ability
| image = Blade Dance (ability).png
| Description = Swing your weapon several times, dealing damage to all enemies in frontal cone.
46 damage and additional 34 from [[Agility]] attribute per instance of damage for a total of 320 [[Sharp]] damage.
| Cooldown = 18
| Cost = 60
}}
'''{{PAGENAME}}''' is an [[Abilities|ability]] in {{BFF}}.
{{Navbox/Abilities}}
b9e47fd084810728c09921e9039f38b023d02462
File:Blade Dance (ability).png
6
1006
1682
2025-09-13T16:18:01Z
Sharparam
284703
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_TwinbladeFlurry2
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/AbilityIcons/New/Icon_TwinbladeFlurry2
}}
== Licensing ==
{{License|game}}
aff4e6fb3a86ce71e79575d3450ddae5555e377f
Passives
0
886
1685
1432
2025-09-13T16:34:42Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
'''Passives''' are special properties that can be found on various [[equipment]], they provide their bonus at all times and don't need to be activated, unlike [[abilities]].
== See also ==
* [[Abilities]]
{{Navbox/Passives}}
[[Category:Passives]]
20da8d383a1a67a9db37a1603312b2f1eb8a7800
Ability
0
1007
1686
2025-09-13T16:35:00Z
Sharparam
284703
Redirected page to [[Abilities]]
wikitext
text/x-wiki
#REDIRECT [[Abilities]]
11b6e51c8d49cd0ea95849da924e56675f48c49b
Passive
0
1008
1687
2025-09-13T16:35:13Z
Sharparam
284703
Redirected page to [[Passives]]
wikitext
text/x-wiki
#REDIRECT [[Passives]]
d0f8c1c729acc790d0ebe9dca573662760756eb4
Template:Infobox/Cape
10
462
1688
689
2025-09-13T16:38:20Z
Sharparam
284703
Add default for title
wikitext
text/x-wiki
<includeonly>{{#invoke:Infobox|main
|kind=cape
|sep=,
|title={{{title|{{PAGENAME}}}}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Effects
|Effects=Effect1,Effect2,Effect3
|Effect1_nolabel=yes
|Effect2_nolabel=yes
|Effect3_nolabel=yes
}}{{#if:{{NAMESPACE}}||[[Category:Capes]]}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
a7caaf53d894f4f0410b98360c79c94d99cc433a
Ronin Scarf
0
1009
1689
2025-09-13T16:39:06Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Ronin Scarf (cape).png | Effect1 = +3 [[Agility]] | Effect2 = +10% [[Sharp]] Armor Penetration }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Ronin Scarf (cape).png
| Effect1 = +3 [[Agility]]
| Effect2 = +10% [[Sharp]] Armor Penetration
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
be26961bc7cb776bedc130e4404d8983e8d97c70
File:Ronin Scarf (cape).png
6
1010
1690
2025-09-13T16:40:11Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/icon_scarfRonin
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/icon_scarfRonin
}}
== Licensing ==
{{License|game}}
c83167cebd43afe4d282ca41d65d242063c48d2e
Agile Cape
0
1011
1691
2025-09-13T16:41:11Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Agile Cape (cape).png | Effect1 = +5 [[Agility]] | Effect2 = +50 [[Stamina]] Recovery per second }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Agile Cape (cape).png
| Effect1 = +5 [[Agility]]
| Effect2 = +50 [[Stamina]] Recovery per second
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
a08fbf207300cc2e840099f00d85ba359d4e87af
File:Agile Cape (cape).png
6
1012
1692
2025-09-13T16:41:47Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CapeTattered1
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CapeTattered1
}}
== Licensing ==
{{License|game}}
11d16186a03e4be636e284c73fc4bfd1a27462ce
Fur Cape
0
1013
1693
2025-09-13T16:42:46Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Fur Cape (cape).png | Effect1 = +0.5 Delay Before [[Stamina]] Regenerates | Effect2 = +10% Attack Power }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Fur Cape (cape).png
| Effect1 = +0.5 Delay Before [[Stamina]] Regenerates
| Effect2 = +10% Attack Power
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
a1607a358e9484587d35f0299d8c081980c56904
File:Fur Cape (cape).png
6
1014
1694
2025-09-13T16:43:35Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_FurCape
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_FurCape
}}
== Licensing ==
{{License|game}}
811f167e0433346ca8fb012e184597107ae7d145
Sentinel Overcoat
0
1015
1695
2025-09-13T16:44:30Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Sentinel Overcoat (cape).png | Effect1 = +3 [[Strength]] | Effect2 = +10% [[Blunt]] Armor Penetration }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Sentinel Overcoat (cape).png
| Effect1 = +3 [[Strength]]
| Effect2 = +10% [[Blunt]] Armor Penetration
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
199c56d814670c0fbe1f3e2d0642287c82c80d4d
File:Sentinel Overcoat (cape).png
6
1016
1696
2025-09-13T16:45:02Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/icon_sentinelovercoat
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/icon_sentinelovercoat
}}
== Licensing ==
{{License|game}}
0932316b595ae1efd59c9f007169e6ac50d8daff
Spectre Scarf
0
1017
1697
2025-09-13T16:45:55Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Spectre Scarf (cape).png | Effect1 = +3 [[Intelligence]] | Effect2 = +15% Critical Damage }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}]"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Spectre Scarf (cape).png
| Effect1 = +3 [[Intelligence]]
| Effect2 = +15% Critical Damage
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}]
9797c65e9bf878df983e20f5e442f40884e0835e
1699
1697
2025-09-13T16:46:37Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Spectre Scarf (cape).png
| Effect1 = +3 [[Intelligence]]
| Effect2 = +15% Critical Damage
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
075c4bc242502504ec881a12e5b0a52078c321ad
File:Spectre Scarf (cape).png
6
1018
1698
2025-09-13T16:46:21Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/icon_scarf
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/icon_scarf
}}
== Licensing ==
{{License|game}}
7ba44884538c21cd17d556d30a9fd1bae170526f
Tattered Cape
0
1019
1700
2025-09-13T16:47:13Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Tattered Cape (cape).png | Effect1 = +10% Stagger Resistance }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Tattered Cape (cape).png
| Effect1 = +10% Stagger Resistance
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
138e3008b085e2d91284c59f670f4c710d144b84
File:Tattered Cape (cape).png
6
1020
1701
2025-09-13T16:47:41Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CapeTattered
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_CapeTattered
}}
== Licensing ==
{{License|game}}
99da13814cf5bfe0dc6471904e1e113f03e2b0d1
Traveler Cape
0
1021
1702
2025-09-13T16:48:33Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Cape | image = Traveler Cape (cape).png | Effect1 = +5% Movement Speed }} '''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}. {{Navbox/Capes}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Cape
| image = Traveler Cape (cape).png
| Effect1 = +5% Movement Speed
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}}.
{{Navbox/Capes}}
48084c9c227f7d891aa4cb8edc6643e5ff9a22e6
File:Traveler Cape (cape).png
6
1022
1703
2025-09-13T16:49:02Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_TravellerCape
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Armors/Icon_TravellerCape
}}
== Licensing ==
{{License|game}}
01c9490a3332e5a3175d0b99815a37b6d96fb60b
Longbow
0
1023
1704
2025-09-13T16:51:08Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Longbow (weapon).png | Type = longbow | Speed = Fast | Damage type = Sharp | Passives = Spare Shot | Abilities = Premeditated Strike | Mk_min = 1 | Mk1_Damage_min = 145 | Mk1_Damage_max = 155 }} '''{{PAGENAME}}''' is a [[Longbows|longbow]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Longbow (weapon).png
| Type = longbow
| Speed = Fast
| Damage type = Sharp
| Passives = Spare Shot
| Abilities = Premeditated Strike
| Mk_min = 1
| Mk1_Damage_min = 145
| Mk1_Damage_max = 155
}}
'''{{PAGENAME}}''' is a [[Longbows|longbow]] in {{BFF}}.
{{Navbox/Weapons}}
650e2dbd8c8d5da68426169d9e71336daa702bb8
File:Longbow (weapon).png
6
1024
1705
2025-09-13T16:51:42Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_BasicBow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_BasicBow
}}
== Licensing ==
{{License|game}}
2988bf44fb365b498c50de80e13a48feeebd3e5c
Ranged weapons
0
659
1706
1019
2025-09-13T16:52:43Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
'''Ranged weapons''' in {{BFF}} can be used to attack enemies at range, without having to get into melee distance.
== Overview ==
There are two types of ranged weapons, [[longbows]] and [[staves]].
{{Navbox/Ranged weapons}}
[[Category:Ranged weapons]]
c9e05fc876b4500dc0a2598e6ae96b70b68fd109
Longbows
0
660
1707
1020
2025-09-13T16:53:03Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
'''Longbows''' are a type of [[Ranged weapons|ranged weapon]] in {{BFF}}. They are currently the only type of bow available.
{{Navbox/Longbows}}
[[Category:Longbows]]
cd170e9044aba6f6d9fb1c8f967eddfc03c2e83e
Template:Navbox/Longbows
10
818
1708
1270
2025-09-13T16:53:18Z
Sharparam
284703
Fix name for winged bow
wikitext
text/x-wiki
{{Navbox
| {{{1|}}}
| state = {{{state|}}}
| template = Navbox/Longbows
| title = [[Longbows]]
| list1 =
* [[Arcane Bow]]
* [[Longbow]]
* [[Taskmaster]]
* [[Winged Bow]]
}}<noinclude>{{Documentation}}</noinclude>
92e2d941a1e3293271ed058e50202e0d473ec836
Winged Bow
0
1025
1709
2025-09-13T16:54:24Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Winged Bow (weapon).png | Type = Longbow | Speed = Fast | Damage type = Sharp | Abilities = Arrow Brutality, Charged Arrow | Mk3_Damage_min = 194 | Mk3_Damage_max = 207 }} '''{{PAGENAME}}''' is a [[Longbows|longbow]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Winged Bow (weapon).png
| Type = Longbow
| Speed = Fast
| Damage type = Sharp
| Abilities = Arrow Brutality, Charged Arrow
| Mk3_Damage_min = 194
| Mk3_Damage_max = 207
}}
'''{{PAGENAME}}''' is a [[Longbows|longbow]] in {{BFF}}.
{{Navbox/Weapons}}
2af5559ce19030294ae8ce010a93a8eb402991cc
File:Winged Bow (weapon).png
6
1026
1710
2025-09-13T16:54:47Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/icon_wingedbow
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/icon_wingedbow
}}
== Licensing ==
{{License|game}}
b5879184f94de6dcfe2bbc51e0272a761578db3a
Evolved Staff
0
1027
1711
2025-09-13T16:56:15Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Evolved Staff (weapon).png | Type = Staff | Speed = Slow | Damage type = Technomancy | Mk0_Damage_min = 49 | Mk0_Damage_max = 50 }} '''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Evolved Staff (weapon).png
| Type = Staff
| Speed = Slow
| Damage type = Technomancy
| Mk0_Damage_min = 49
| Mk0_Damage_max = 50
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}.
{{Navbox/Weapons}}
1210043d143c13c1eba3e2572c7728d2d3705198
File:Evolved Staff (weapon).png
6
1028
1712
2025-09-13T16:56:43Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_EvolvedStaffNew
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_EvolvedStaffNew
}}
== Licensing ==
{{License|game}}
9c4d3c85a9d54e936188036425bb5e844ae5eb27
Mechanomad Staff
0
1029
1713
2025-09-13T16:57:45Z
Sharparam
284703
Created page with "{{Needs location}} {{Infobox/Weapon | image = Mechanomad Staff (weapon).png | Type = Staff | Speed = Slow | Damage type = Technomancy | Mk0_Damage_min = 49 | Mk0_Damage_max = 50 }} '''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}. {{Navbox/Weapons}}"
wikitext
text/x-wiki
{{Needs location}}
{{Infobox/Weapon
| image = Mechanomad Staff (weapon).png
| Type = Staff
| Speed = Slow
| Damage type = Technomancy
| Mk0_Damage_min = 49
| Mk0_Damage_max = 50
}}
'''{{PAGENAME}}''' is a [[Staves|staff]] in {{BFF}}.
{{Navbox/Weapons}}
abc6b834084e76b5d3cc23245bd05ff84360c6db
File:Mechanomad Staff (weapon).png
6
1030
1714
2025-09-13T16:58:10Z
Sharparam
284703
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_MechanomadStaff.
}}
wikitext
text/x-wiki
== Summary ==
{{Game image
| path = Game/Textures/EquipmentIcons/New/Weapons/Icon_MechanomadStaff.
}}
== Licensing ==
{{License|game}}
4f8863c9a8d014e23902360f4115eae1e6d0a2d4
Anomalous crystals
0
427
1715
617
2025-09-13T17:01:15Z
Sharparam
284703
Add note on extraction
wikitext
text/x-wiki
'''{{PAGENAME}}''' are [[items]] that can be embedded into [[equipment]] ([[armor]] or [[weapons]] only) to improve their properties.
== Overview ==
There are three "tiers" of crystals: '''[[Lesser Anomalous Crystal|lesser]]''', '''[[Anomalous Crystal|normal]]''', and '''[[Greater Anomalous Crystal|greater]]'''.
Crystals can only be embedded into equipment by [[The Handler]]. Embedding a crystal into a slot destroys any crystal that is already occupying said slot, causing it to be lost forever.
Unwanted crystals can be destroyed by extracting essence from them in the inventory, one crystal (regardless of tier) grants one essence when extracted.
{{Navbox/Items}}
[[Category:Anomalous crystals]]
d2a2bb73ae64ca30747d98ab5cfef8721182b0b2
Ammunition
0
814
1716
1264
2025-09-13T17:01:55Z
Sharparam
284703
Fix typo
wikitext
text/x-wiki
'''{{PAGENAME}}''' are items that can be shot with [[longbows]].
{{Navbox/Ammunition}}
[[Category:Ammunition]]
cc83a8d360dcc7f109694ab4c21f0ae311b310bb
Upgrade items
0
662
1717
1022
2025-09-13T17:02:42Z
Sharparam
284703
Move equipment link
wikitext
text/x-wiki
'''Upgrade items''' in {{BFF}} can be used to upgrade [[equipment]] to higher mark levels.
== Overview ==
There are two upgrade items available.
=== Upgrade Splinter ===
{{Main|Upgrade Splinter}}
Upgrade splinters are used to upgrade equipment to Mk 1, 2, and 3.
=== Upgrade Modules ===
{{Main|Upgrade Module}}
Upgrade modules are used to upgrade equipment to Mk 4 and 5.
[[Category:Upgrade items]]
6c65a41a767ff088faff06fa3c60df4e40e5d288
1718
1717
2025-09-13T17:03:10Z
Sharparam
284703
Add navbox
wikitext
text/x-wiki
'''Upgrade items''' in {{BFF}} can be used to upgrade [[equipment]] to higher mark levels.
== Overview ==
There are two upgrade items available.
=== Upgrade Splinter ===
{{Main|Upgrade Splinter}}
Upgrade splinters are used to upgrade equipment to Mk 1, 2, and 3.
=== Upgrade Modules ===
{{Main|Upgrade Module}}
Upgrade modules are used to upgrade equipment to Mk 4 and 5.
{{Navbox/Essential items}}
[[Category:Upgrade items]]
3fa4114361dde368f8d5149cfa5e5186640ac550
Essential items
0
665
1719
1026
2025-09-13T17:04:05Z
Sharparam
284703
Add description
wikitext
text/x-wiki
'''Essential items''' are important [[items]] in the game, either for progression or upgrading [[equipment]].
{{Navbox/Essential items}}
[[Category:Essential items]]
e4ce9ed78441611f20c3c1fffdf6ceb7ff482a4f
Template:BFF
10
346
1720
459
2025-09-13T17:04:59Z
Sharparam
284703
Protected "[[Template:BFF]]": Widely transcluded ([Edit=Allow only administrators] (indefinite) [Rename=Allow only administrators] (indefinite))
wikitext
text/x-wiki
''[[Bleak Faith: Forsaken]]''
a07fd38648935c2ecd381aa47db3694dae3fb873
1721
1720
2025-09-13T17:05:44Z
Sharparam
284703
Add documentation
wikitext
text/x-wiki
''[[Bleak Faith: Forsaken]]''<noinclude>{{Documentation}}</noinclude>
37316fd90539b5b11f099a0497c71388ccc8a405
Template:BFF/doc
10
1031
1722
2025-09-13T17:07:21Z
Sharparam
284703
Created page with "Used to produce a link to the game's article, with proper formatting. == TemplateData == <templatedata> { "params": {}, "description": "Used to produce a link to the game's article, with proper formatting.", "format": "inline" } </templatedata> == Example == * <syntaxhighlight lang="wikitext" inline>{{BFF}}</syntaxhighlight> → {{BFF}} <includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly><!-- --><noinclude>[[Category:Template documentation]]</noi..."
wikitext
text/x-wiki
Used to produce a link to the game's article, with proper formatting.
== TemplateData ==
<templatedata>
{
"params": {},
"description": "Used to produce a link to the game's article, with proper formatting.",
"format": "inline"
}
</templatedata>
== Example ==
* <syntaxhighlight lang="wikitext" inline>{{BFF}}</syntaxhighlight> → {{BFF}}
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
f6195706a649006c85d6c9c2c81995d9b2ce4314
1723
1722
2025-09-13T17:10:08Z
Sharparam
284703
Update categorization
wikitext
text/x-wiki
Used to produce a link to the game's article, with proper formatting.
== TemplateData ==
<templatedata>
{
"params": {},
"description": "Used to produce a link to the game's article, with proper formatting.",
"format": "inline"
}
</templatedata>
== Example ==
* <syntaxhighlight lang="wikitext" inline>{{BFF}}</syntaxhighlight> → {{BFF}}
<includeonly>[[Category:Templates]]</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
260a69a9c0b54df8f57bd374581c9def8835d210
Deluge
0
356
1724
1509
2025-09-13T17:15:48Z
Sharparam
284703
Add enemy list
wikitext
text/x-wiki
[[File:Deluge.png|thumb|Deluge as depicted in the game's relocation menu.|alt=Artwork showing the Deluge area filled with water with structures lining the sides.]]
'''{{PAGENAME}}''' is a location in {{BFF}}.
{{Quote
| A vast reservoir stretches out like a somber mirror, its surface eerily still, broken only by the faintest ripples. Shadowy shapes drift beneath the dark water, their forms indistinct and haunting.
}}
== NPCs ==
* [[The Handler]]
== Enemies ==
* [[Fisherman]]
{{Navbox/Locations}}
[[Category:Locations]]
8bcb7f6fd26e25cf5edd2c9c098ffc8f66e968ef
Archinquisitor Belisarius
0
401
1725
564
2025-09-13T17:23:38Z
Sharparam
284703
Update image name
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Archinquisitor Belisarius (boss)}}
{{stub}}
{{Infobox/NPC
| image = Archinquisitor Belisarius (NPC).png
}}
{{Navbox/NPCs}}
37acab4f9f5d248cfaf4cbfd488ab7b9eb7e8d17
1727
1725
2025-09-13T17:30:22Z
Sharparam
284703
Add more information
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Archinquisitor Belisarius (boss)}}
{{Infobox/NPC
| image = Archinquisitor Belisarius (NPC).png
}}
== Location ==
{{coords|3470.22|23631.83|-20680.39}}
Located in the [[Machinarium]], inside a small temple leading to a cave. The entrance is in the forest area after defeating [[Aberrant Knight]].
== Quotes ==
=== On first encounter ===
{{Quote
|I emphathize with those we purify… But when I lay my hands on [[the Serdars]]… Hell will seem like Heaven!
If we could only do away with everything here, altogether…
A marvellous conception, a supreme figure, an exalted shadow, an infinite representation of the excellence and supremacy that transcends comprehension or grasp. Thus is the excellence of the [[God-Emperor]] and the greatness of his domains made manifest. He will be glorified not in one, but in countless suns. Not in a single realm but in a thousand!
I do not like forced conversations, so – if you please…
There is no meaning to an existence with no beginning and no end, and I no longer wish to indulge it with conversation. Out of my sight.
}}
=== On subsequent encounters ===
{{Quote|There is no meaning to an existence with no beginning and no end, and I no longer wish to indulge it with conversation. Out of my sight.}}
{{Navbox/NPCs}}
b3208bc5094affe5c8dc01a8d3b218ad475f101a
1728
1727
2025-09-13T17:31:50Z
Sharparam
284703
Add introduction
wikitext
text/x-wiki
{{About|the [[NPC]]|the [[Bosses|boss]]|Archinquisitor Belisarius (boss)}}
{{Infobox/NPC
| image = Archinquisitor Belisarius (NPC).png
}}
'''Archinquisitor Belisarius''' is an [[NPCs|NPC]] in {{BFF}}. The player will later encounter him as a [[Bosses|boss]] near the end of the game.
== Location ==
{{coords|3470.22|23631.83|-20680.39}}
Located in the [[Machinarium]], inside a small temple leading to a cave. The entrance is in the forest area after defeating [[Aberrant Knight]].
== Quotes ==
=== On first encounter ===
{{Quote
|I emphathize with those we purify… But when I lay my hands on [[the Serdars]]… Hell will seem like Heaven!
If we could only do away with everything here, altogether…
A marvellous conception, a supreme figure, an exalted shadow, an infinite representation of the excellence and supremacy that transcends comprehension or grasp. Thus is the excellence of the [[God-Emperor]] and the greatness of his domains made manifest. He will be glorified not in one, but in countless suns. Not in a single realm but in a thousand!
I do not like forced conversations, so – if you please…
There is no meaning to an existence with no beginning and no end, and I no longer wish to indulge it with conversation. Out of my sight.
}}
=== On subsequent encounters ===
{{Quote|There is no meaning to an existence with no beginning and no end, and I no longer wish to indulge it with conversation. Out of my sight.}}
{{Navbox/NPCs}}
a68805c0d737cc497b94917641f7c31fcd301908
File:Archinquisitor Belisarius (NPC).png
6
1032
1726
2025-09-13T17:23:58Z
Sharparam
284703
wikitext
text/x-wiki
== Licensing ==
{{License|fairuse}}
87d7977e3529dee7284946acd854ac7b16cf2467
Module:Recipe/doc
828
917
1729
1526
2025-09-13T17:35:10Z
Sharparam
284703
Use valid results and ingredients
wikitext
text/x-wiki
This module should not be used directly, instead use it via the {{tl|Recipe}} template.
== Styles ==
* [[Module:Recipe/styles.css]]
== Test cases ==
=== Simple single ingredient recipe ===
<syntaxhighlight lang="wikitext">
{{#invoke:Recipe|main
|result = Restorative Fluid
|ingredient = Gingko Leaves
}}
</syntaxhighlight>
{{#invoke:Recipe|main
|result = Restorative Fluid
|ingredient = Gingko Leaves
}}
=== Multiple ingredients ===
<syntaxhighlight lang="wikitext">
{{#invoke:Recipe|main
|result = Greater Restorative Fluid
|ingredient1 = Sludge
|ingredient2 = Gingko Leaves
}}
</syntaxhighlight>
{{#invoke:Recipe|main
|result = Greater Restorative Fluid
|ingredient1 = Sludge
|ingredient2 = Gingko Leaves
}}
<includeonly>{{Sandbox other||[[Category:Modules]]}}</includeonly><!--
--><noinclude>[[Category:Module documentation pages]]</noinclude>
88e2030ec6ad85bf856aa6f36b49911ced32abbd
Template:Recipe/doc
10
920
1730
1530
2025-09-13T17:36:40Z
Sharparam
284703
Use valid items in examples
wikitext
text/x-wiki
== Examples ==
=== Simple recipe with single ingredient ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Restorative Fluid
| ingredient = Gingko Leaves
}}
</syntaxhighlight>
{{Recipe
| result = Restorative Fluid
| ingredient = Gingko Leaves
}}
=== Multiple ingredients ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Greater Restorative Fluid
| ingredient1 = Sludge
| ingredient2 = Gingko Leaves
}}
</syntaxhighlight>
{{Recipe
| result = Greater Restorative Fluid
| ingredient1 = Sludge
| ingredient2 = Gingko Leaves
}}
=== Manufacturing recipe ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Mystery Concoction
| ingredient = Sludge
| type = manufacturing
}}
</syntaxhighlight>
{{Recipe
| result = Mystery Concoction
| ingredient = Sludge
| type = manufacturing
}}
=== Quantities ===
<syntaxhighlight lang="wikitext">
{{Recipe
| result = Metal Arrows
| result_quantity = 10
| ingredient1 = Machinite
| ingredient1_quantity = 5
| ingredient2 = Sludge
| ingredient2_quantity = 2
| ingredient3 = Gingko Leaves
| ingredient3_quantity = 10
| type = crafting
}}
</syntaxhighlight>
{{Recipe
| result = Metal Arrows
| result_quantity = 10
| ingredient1 = Machinite
| ingredient1_quantity = 5
| ingredient2 = Sludge
| ingredient2_quantity = 2
| ingredient3 = Gingko Leaves
| ingredient3_quantity = 10
| type = crafting
}}
<includeonly>{{Sandbox other||[[Category:Templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
d152f85b96c4ccf5584d304936e74be664106ea1
Techpriest Cape
0
515
1731
1033
2025-09-13T17:39:36Z
Sharparam
284703
Fix interwiki link
wikitext
text/x-wiki
{{Infobox/Cape
| image = Techpriest Cape.png
| title = {{PAGENAME}}
| Effect1 = +50 Max [[flux]] points.
| Effect2 = +150 [[Flux]] leech rating.
}}
'''{{PAGENAME}}''' is a [[Capes|cape]] in {{BFF}} that can be worn by the player.
== Location ==
{{coords|-4527|8973|9614}}
Found in [[Asylum]]. After entering the first courtyard, climb the stairs on the right and jump onto the right ledge, then follow it backwards (towards the direction you entered from) and the item will be on a corpse on the left.
== Trivia ==
* "Techpriest" in the name might be a reference to [https://wh40k.lexicanum.com/wiki/Tech-priest tech-priests] from [[wikipedia:Warhammer 40,000|Warhammer 40,000]].
* The cape is called "HighPriestCape" in the game files.
{{Navbox/Capes}}
dc3568f0be90eee43efeafc7d9ad950530eaef8b
Greatweapon
0
1033
1732
2025-09-13T17:40:36Z
Sharparam
284703
Redirected page to [[Greatweapons]]
wikitext
text/x-wiki
#REDIRECT [[Greatweapons]]
1e761b4aa7eac6f5415739067c330950b195d7f0
Staff
0
1034
1733
2025-09-13T17:40:49Z
Sharparam
284703
Redirected page to [[Staves]]
wikitext
text/x-wiki
#REDIRECT [[Staves]]
695e27b9fb3bc2aedd279a23c2ed933b3df0478b
Two-handed
0
1035
1734
2025-09-13T17:41:10Z
Sharparam
284703
Redirected page to [[Two-handed weapons]]
wikitext
text/x-wiki
#REDIRECT [[Two-handed weapons]]
26b71e9dcde020e910bf0237e4781f8038ef353e
One-handed
0
1036
1735
2025-09-13T17:41:23Z
Sharparam
284703
Redirected page to [[One-handed weapons]]
wikitext
text/x-wiki
#REDIRECT [[One-handed weapons]]
72c8194c2cd8818bb06c5f772d5f0501cc48e935
Template:Infobox/Weapon
10
451
1736
1661
2025-09-13T17:42:48Z
Sharparam
284703
Fix name resolution
wikitext
text/x-wiki
<includeonly>{{#vardefine:name|{{{title|{{PAGENAME}}}}}}}{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{#var:name}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| template = Passive link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| template = Ability link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| greatweapon = [[Greatweapons|Greatweapon]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| greatweapon = [[Category:Greatweapons]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{#var:name}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| greatweapon = greatweapon
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
648952ec0a0f6a575c636d80aa897ba29a8dfc1a
1742
1736
2025-09-13T17:52:00Z
Sharparam
284703
Use damage type template
wikitext
text/x-wiki
<includeonly>{{#vardefine:name|{{{title|{{PAGENAME}}}}}}}{{#invoke:Infobox|main
|kind=weapon
|sep=,
|title={{#var:name}}
|image={{#if:{{{image|}}}|[[File:{{{image}}}{{!}}300px]]}}
|sections=Basic Info, Stats
|Basic Info=Type,Speed,Damage type,Passives,Abilities
|Passives={{#listmap:
| list = {{{Passives|}}}
| outsep = \n
| token = @@@@
| template = Passive link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Passives_label={{#ifeq:{{#lstcnt:{{{Passives|}}}}}|1|Passive|Passives}}
|Abilities={{#listmap:
| list = {{{Abilities|}}}
| outsep = \n
| token = @@@@
| template = Ability link item
| intro = \{\{Plainlist\!
| outro = \}\}
}}
|Abilities_label={{#ifeq:{{#lstcnt:{{{Abilities|}}}}}|1|Ability|Abilities}}
|Type={{#if:{{{Type|}}}|{{#switch:{{lc:{{{Type}}}}}
| one-handed = [[One-handed weapons|One-handed]]
| two-handed = [[Two-handed weapons|Two-handed]]
| dual wield = [[Dual Wield]]
| twinblade = [[Twinblades|Twinblade]]
| greatweapon = [[Greatweapons|Greatweapon]]
| bow
| longbow = [[Longbows|Longbow]]
| ranged = [[Ranged weapons|Ranged]]
| staff = [[Staves|Staff]]
| #default = {{{Type}}}
}}}}
|Damage type={{#if:{{{Damage type|}}}|{{Damage type|{{{Damage type}}}}}}}
|tabs={{#switch:{{{Mk_min|0}}}
|1 = Mk1,Mk2,Mk3,Mk4,Mk5
|2 = Mk2,Mk3,Mk4,Mk5
|3 = Mk3,Mk4,Mk5
|4 = Mk4,Mk5
|5 = Mk5
|#default = Mk0,Mk1,Mk2,Mk3,Mk4,Mk5
}}
|Mk0_label=Mk 0
|Mk1_label=Mk 1
|Mk2_label=Mk 2
|Mk3_label=Mk 3
|Mk4_label=Mk 4
|Mk5_label=Mk 5
|Stats=Damage
|Mk0_Damage={{DamageRange|{{{Mk0_Damage_min|???}}}|{{{Mk0_Damage_max|???}}}}}
|Mk1_Damage={{DamageRange|{{{Mk1_Damage_min|???}}}|{{{Mk1_Damage_max|???}}}}}
|Mk2_Damage={{DamageRange|{{{Mk2_Damage_min|???}}}|{{{Mk2_Damage_max|???}}}}}
|Mk3_Damage={{DamageRange|{{{Mk3_Damage_min|???}}}|{{{Mk3_Damage_max|???}}}}}
|Mk4_Damage={{DamageRange|{{{Mk4_Damage_min|???}}}|{{{Mk4_Damage_max|???}}}}}
|Mk5_Damage={{DamageRange|{{{Mk5_Damage_min|???}}}|{{{Mk5_Damage_max|???}}}}}
}}{{#if:{{NAMESPACE}}||{{#switch:{{lc:{{{Type|}}}}}
| one-handed = [[Category:One-handed weapons]]
| two-handed = [[Category:Two-handed weapons]]
| dual wield = [[Category:Dual Wields]]
| twinblade = [[Category:Twinblades]]
| greatweapon = [[Category:Greatweapons]]
| bow
| longbow = [[Category:Longbows]]
| ranged = [[Category:Ranged weapons]]
| staff = [[Category:Staves]]
| #default = [[Category:Weapons]]
}}{{Weapons/CargoStore
|name={{#var:name}}
|type={{#switch:{{lc:{{{Type}}}}}
| one-handed = one-handed
| two-handed = two-handed
| dual wield = dual wield
| twinblade = twinblade
| greatweapon = greatweapon
| bow
| longbow = longbow
| ranged = ranged
| staff = staff
| #default = unknown
}}
|speed={{#if:{{{Speed|}}}|{{lc:{{{Speed}}}}}}}
|damageType={{#if:{{{Damage type|}}}|{{#switch:{{lc:{{{Damage type}}}}}
| sharp = sharp
| blunt = blunt
| tech
| technomancy = technomancy
}}}}
|damageMk0Min={{{Mk0_Damage_min|}}}
|damageMk0Max={{{Mk0_Damage_max|}}}
|damageMk1Min={{{Mk1_Damage_min|}}}
|damageMk1Max={{{Mk1_Damage_max|}}}
|damageMk2Min={{{Mk2_Damage_min|}}}
|damageMk2Max={{{Mk2_Damage_max|}}}
|damageMk3Min={{{Mk3_Damage_min|}}}
|damageMk3Max={{{Mk3_Damage_max|}}}
|damageMk4Min={{{Mk4_Damage_min|}}}
|damageMk4Max={{{Mk4_Damage_max|}}}
|damageMk5Min={{{Mk5_Damage_min|}}}
|damageMk5Max={{{Mk5_Damage_max|}}}
}}}}</includeonly><noinclude>{{Documentation}}[[Category:Infobox templates]]</noinclude>
c7a1675b3627d1c2e3ea681c310cbb46b80eadd6
Blunt
0
1037
1737
2025-09-13T17:43:31Z
Sharparam
284703
Created page with "'''Blunt''' is a type of damage in {{BFF}}. [[Category:Game mechanics]]"
wikitext
text/x-wiki
'''Blunt''' is a type of damage in {{BFF}}.
[[Category:Game mechanics]]
01f1c4d287033b2532357615f04edb64b5d5e46f
Sharp
0
526
1738
813
2025-09-13T17:43:53Z
Sharparam
284703
Add category
wikitext
text/x-wiki
'''Sharp''' is a type of damage in {{BFF}}.
[[Category:Game mechanics]]
cce1ce9bc84831c31b53fbafed846e82615d4eaa
Template:Damage type
10
1038
1739
2025-09-13T17:48:11Z
Sharparam
284703
Created page with "{{#switch:{{lc:{{{1}}}}} | sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]] | blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]] | tech | technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]] | #default = {{{Damage type}}} }}<!-- --><noinclude>{{Documentation}}</noinclude>"
wikitext
text/x-wiki
{{#switch:{{lc:{{{1}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{Damage type}}}
}}<!--
--><noinclude>{{Documentation}}</noinclude>
d6f3d0b6d394b2e121f2f614e3c29a26a1ea3429
1740
1739
2025-09-13T17:48:30Z
Sharparam
284703
Fix wrong variable used
wikitext
text/x-wiki
{{#switch:{{lc:{{{1}}}}}
| sharp = [[File:Sharp_outlined.png|20px|link=Sharp]] [[Sharp]]
| blunt = [[File:Blunt_outlined.png|20px|link=Blunt]] [[Blunt]]
| tech
| technomancy = [[File:Technomancy_outlined.png|20px|link=Technomancy]] [[Technomancy]]
| #default = {{{1}}}
}}<!--
--><noinclude>{{Documentation}}</noinclude>
e96e740f90b54922fa87b26908a3cd35fa581e42
Template:Damage type/doc
10
1039
1741
2025-09-13T17:51:15Z
Sharparam
284703
Created page with "Creates a formatted link to one of the three damage types. == TemplateData == <templatedata> { "params": { "1": { "label": "Damage type", "description": "The damage type to link to.", "example": "Sharp", "type": "line", "suggestedvalues": [ "sharp", "blunt", "technomancy" ], "required": true } }, "description": "Creates a link to a damage type, including relevant icon.", "format": "inline" } </templatedata> == Examples == * <syn..."
wikitext
text/x-wiki
Creates a formatted link to one of the three damage types.
== TemplateData ==
<templatedata>
{
"params": {
"1": {
"label": "Damage type",
"description": "The damage type to link to.",
"example": "Sharp",
"type": "line",
"suggestedvalues": [
"sharp",
"blunt",
"technomancy"
],
"required": true
}
},
"description": "Creates a link to a damage type, including relevant icon.",
"format": "inline"
}
</templatedata>
== Examples ==
* <syntaxhighlight lang="wikitext" inline>{{Damage type|sharp}}</syntaxhighlight> → {{Damage type|sharp}}
* <syntaxhighlight lang="wikitext" inline>{{Damage type|blunt}}</syntaxhighlight> → {{Damage type|blunt}}
* <syntaxhighlight lang="wikitext" inline>{{Damage type|technomancy}}</syntaxhighlight> → {{Damage type|technomancy}}
* <syntaxhighlight lang="wikitext" inline>{{Damage type|tech}}</syntaxhighlight> → {{Damage type|tech}}
<includeonly>{{Sandbox other||[[Category:Formatting templates]]}}</includeonly><!--
--><noinclude>[[Category:Template documentation]]</noinclude>
e257f4fab4a45f3e90e5c87bbbc11b24aa0f7939
Weapons
0
465
1743
695
2025-09-13T17:52:56Z
Sharparam
284703
Use damage type template in table
wikitext
text/x-wiki
'''{{PAGENAME}}''' are a type of [[equipment]] in {{BFF}} used to engage in melee combat with [[enemies]].
== Upgrading ==
Weapons can be upgraded all the way to Mk 5 by speaking to [[The Handler]] and giving her the requisite materials.
Upgrading a weapon increases its damage as well as allowing you to embed more crystals into it to improve its properties further. Some weapons will also unlock passive bonuses or abilities when they are upgraded.
== List of weapons ==
{{#cargo_query:table=Weapons
|fields=CONCAT('[[', name, ']]')=Name, CONCAT('[[', type, ']]')=Type, speed=Speed, CONCAT('{{((}}Damage type{{!}}', damageType, '{{))}}')=Damage type, CONCAT("{{((}}DamageRange{{!}}", damageMk0Min, '{{!}}', damageMk0Max, '{{))}}')=Damage (Mk 0), CONCAT("{{((}}DamageRange{{!}}", damageMk1Min, '{{!}}', damageMk1Max, '{{))}}')=Damage (Mk 1), CONCAT("{{((}}DamageRange{{!}}", damageMk2Min, '{{!}}', damageMk2Max, '{{))}}')=Damage (Mk 2), CONCAT("{{((}}DamageRange{{!}}", damageMk3Min, '{{!}}', damageMk3Max, '{{))}}')=Damage (Mk 3), CONCAT("{{((}}DamageRange{{!}}", damageMk4Min, '{{!}}', damageMk4Max, '{{))}}')=Damage (Mk 4), CONCAT("{{((}}DamageRange{{!}}", damageMk5Min, '{{!}}', damageMk5Max, '{{))}}')=Damage (Mk 5)
|format=table
}}
{{Navbox/Weapons}}
c7b3076333c274bb0420ef5b86f4d35132e6dfe6